DeveelDB  20151217
complete SQL database system, primarly developed for .NET/Mono frameworks
EquiJoinNode.cs
Go to the documentation of this file.
1 //
2 // Copyright 2010-2015 Deveel
3 //
4 // Licensed under the Apache License, Version 2.0 (the "License");
5 // you may not use this file except in compliance with the License.
6 // You may obtain a copy of the License at
7 //
8 // http://www.apache.org/licenses/LICENSE-2.0
9 //
10 // Unless required by applicable law or agreed to in writing, software
11 // distributed under the License is distributed on an "AS IS" BASIS,
12 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 // See the License for the specific language governing permissions and
14 // limitations under the License.
15 //
16 
17 using System;
18 
19 using Deveel.Data;
21 using Deveel.Data.Sql.Tables;
22 
23 namespace Deveel.Data.Sql.Query {
24  [Serializable]
26  public EquiJoinNode(IQueryPlanNode left, IQueryPlanNode right, ObjectName[] leftColumns, ObjectName[] rightColumns)
27  : base(left, right) {
28  LeftColumns = leftColumns;
29  RightColumns = rightColumns;
30  }
31 
32  private EquiJoinNode(ObjectData data)
33  : base(data) {
34  LeftColumns = data.GetValue<ObjectName[]>("LeftColumns");
35  RightColumns = data.GetValue<ObjectName[]>("RightColumns");
36  }
37 
38  public ObjectName[] LeftColumns { get; private set; }
39 
40  public ObjectName[] RightColumns { get; private set; }
41 
42  public override ITable Evaluate(IRequest context) {
43  // Solve the left branch result
44  var leftResult = Left.Evaluate(context);
45  // Solve the right branch result
46  var rightResult = Right.Evaluate(context);
47 
48  return leftResult.EquiJoin(context, rightResult, LeftColumns, RightColumns);
49  }
50 
51  protected override void GetData(SerializeData data) {
52  data.SetValue("LeftColumns", LeftColumns);
53  data.SetValue("RightColumns", RightColumns);
54  }
55  }
56 }
override void GetData(SerializeData data)
Definition: EquiJoinNode.cs:51
Defines the contract to access the data contained into a table of a database.
Definition: ITable.cs:40
override ITable Evaluate(IRequest context)
Definition: EquiJoinNode.cs:42
EquiJoinNode(IQueryPlanNode left, IQueryPlanNode right, ObjectName[] leftColumns, ObjectName[] rightColumns)
Definition: EquiJoinNode.cs:26
void SetValue(string key, Type type, object value)
Describes the name of an object within a database.
Definition: ObjectName.cs:44
A node element of a query plan tree. /summary>
A IQueryPlanNode implementation that is a branch with two child nodes.