DeveelDB  20151217
complete SQL database system, primarly developed for .NET/Mono frameworks
SubsetNode.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 
20 using Deveel.Data.Sql.Tables;
21 
22 namespace Deveel.Data.Sql.Query {
23  [Serializable]
25  public SubsetNode(IQueryPlanNode child, ObjectName[] originalColumnNames, ObjectName[] aliasColumnNames)
26  : base(child) {
27  OriginalColumnNames = originalColumnNames;
28  AliasColumnNames = aliasColumnNames;
29  }
30 
31  private SubsetNode(ObjectData data)
32  : base(data) {
33  OriginalColumnNames = data.GetValue<ObjectName[]>("OriginalColumns");
34  AliasColumnNames = data.GetValue<ObjectName[]>("AliasColumns");
35  }
36 
37  public ObjectName[] OriginalColumnNames { get; private set; }
38 
39  public ObjectName[] AliasColumnNames { get; private set; }
40 
41  public override ITable Evaluate(IRequest context) {
42  var table = Child.Evaluate(context);
43  return table.Subset(OriginalColumnNames, AliasColumnNames);
44  }
45 
46  public void SetAliasParentName(ObjectName parentName) {
47  var aliases = new ObjectName[AliasColumnNames.Length];
48  for (int i = 0; i < aliases.Length; i++) {
49  aliases[i] = new ObjectName(parentName, aliases[i].Name);
50  }
51 
52  AliasColumnNames = aliases;
53  }
54 
55  protected override void GetData(SerializeData data) {
56  data.SetValue("OriginalColumns", OriginalColumnNames);
57  data.SetValue("AliasColumns", AliasColumnNames);
58  }
59  }
60 }
Defines the contract to access the data contained into a table of a database.
Definition: ITable.cs:40
A IQueryPlanNode with a single child.
A query to the database to select data from a set of tables and columns.
override ITable Evaluate(IRequest context)
Definition: SubsetNode.cs:41
void SetAliasParentName(ObjectName parentName)
Definition: SubsetNode.cs:46
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>
SubsetNode(IQueryPlanNode child, ObjectName[] originalColumnNames, ObjectName[] aliasColumnNames)
Definition: SubsetNode.cs:25
override void GetData(SerializeData data)
Definition: SubsetNode.cs:55