DeveelDB  20151217
complete SQL database system, primarly developed for .NET/Mono frameworks
NaturalJoinNode.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 using System.Collections.Generic;
19 
20 using Deveel.Data;
22 using Deveel.Data.Sql.Tables;
23 
24 namespace Deveel.Data.Sql.Query {
32  [Serializable]
35  : base(left, right) {
36  }
37 
39  : base(data) {
40  }
41 
42  public override ITable Evaluate(IRequest context) {
43  // Solve the left branch result
44  var leftResult = Left.Evaluate(context);
45  // Solve the Join (natural)
46  return leftResult.NaturalJoin(Right.Evaluate(context));
47  }
48  }
49 }
Defines the contract to access the data contained into a table of a database.
Definition: ITable.cs:40
NaturalJoinNode(IQueryPlanNode left, IQueryPlanNode right)
A node element of a query plan tree. /summary>
override ITable Evaluate(IRequest context)
A branch node for naturally joining two tables together.
A IQueryPlanNode implementation that is a branch with two child nodes.