Mercurial > pub > bltoolkit
comparison Source/Data/Linq/Builder/IntersectBuilder.cs @ 0:f990fcb411a9
Копия текущей версии из github
author | cin |
---|---|
date | Thu, 27 Mar 2014 21:46:09 +0400 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:f990fcb411a9 |
---|---|
1 using System; | |
2 using System.Linq.Expressions; | |
3 | |
4 namespace BLToolkit.Data.Linq.Builder | |
5 { | |
6 using BLToolkit.Linq; | |
7 using Data.Sql; | |
8 | |
9 class IntersectBuilder : MethodCallBuilder | |
10 { | |
11 protected override bool CanBuildMethodCall(ExpressionBuilder builder, MethodCallExpression methodCall, BuildInfo buildInfo) | |
12 { | |
13 return methodCall.Arguments.Count == 2 && methodCall.IsQueryable("Except", "Intersect"); | |
14 } | |
15 | |
16 protected override IBuildContext BuildMethodCall(ExpressionBuilder builder, MethodCallExpression methodCall, BuildInfo buildInfo) | |
17 { | |
18 var sequence = builder.BuildSequence(new BuildInfo(buildInfo, methodCall.Arguments[0])); | |
19 var query = builder.BuildSequence(new BuildInfo(buildInfo, methodCall.Arguments[1], new SqlQuery())); | |
20 var except = query.SqlQuery; | |
21 | |
22 sequence = new SubQueryContext(sequence); | |
23 | |
24 var sql = sequence.SqlQuery; | |
25 | |
26 except.ParentSql = sql; | |
27 | |
28 if (methodCall.Method.Name == "Except") | |
29 sql.Where.Not.Exists(except); | |
30 else | |
31 sql.Where.Exists(except); | |
32 | |
33 var keys1 = sequence.ConvertToSql(null, 0, ConvertFlags.Key); | |
34 var keys2 = query. ConvertToSql(null, 0, ConvertFlags.Key); | |
35 | |
36 if (keys1.Length != keys2.Length) | |
37 throw new InvalidOperationException(); | |
38 | |
39 for (var i = 0; i < keys1.Length; i++) | |
40 { | |
41 except.Where | |
42 .Expr(keys1[i].Sql) | |
43 .Equal | |
44 .Expr(keys2[i].Sql); | |
45 } | |
46 | |
47 return sequence; | |
48 } | |
49 | |
50 protected override SequenceConvertInfo Convert( | |
51 ExpressionBuilder builder, MethodCallExpression methodCall, BuildInfo buildInfo, ParameterExpression param) | |
52 { | |
53 return null; | |
54 } | |
55 } | |
56 } |