DeveelDB  20151217
complete SQL database system, primarly developed for .NET/Mono frameworks
LeftOuterJoinNode.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 {
47  [Serializable]
49  public LeftOuterJoinNode(IQueryPlanNode child, string markerName)
50  : base(child) {
51  MarkerName = markerName;
52  }
53 
55  : base(data) {
56  MarkerName = data.GetString("Marker");
57  }
58 
59  public string MarkerName { get; private set; }
60 
61  public override ITable Evaluate(IRequest context) {
62  // Evaluate the child branch,
63  var result = Child.Evaluate(context);
64  // Get the table of the complete mark name,
65  var completeLeft = context.Query.GetCachedTable(MarkerName);
66 
67  // The rows in 'complete_left' that are outside (not in) the rows in the
68  // left result.
69  var outside = completeLeft.OuterJoin(result);
70 
71  // Create an OuterTable
72  var outerTable = OuterTable.Create(result);
73  outerTable.MergeIn(outside);
74 
75  // Return the outer table
76  return outerTable;
77  }
78 
79  protected override void GetData(SerializeData data) {
80  data.SetValue("Marker", MarkerName);
81  }
82  }
83 }
override void GetData(SerializeData data)
Defines the contract to access the data contained into a table of a database.
Definition: ITable.cs:40
A IQueryPlanNode with a single child.
static OuterTable Create(ITable inputTable)
Definition: OuterTable.cs:32
void SetValue(string key, Type type, object value)
A node element of a query plan tree. /summary>
LeftOuterJoinNode(IQueryPlanNode child, string markerName)
void MergeIn(ITable outsideTable)
Definition: OuterTable.cs:44
A branch node for a left outer join.
override ITable Evaluate(IRequest context)