DeveelDB  20151217
complete SQL database system, primarly developed for .NET/Mono frameworks
SimpleSelectNode.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;
22 using Deveel.Data.Sql.Tables;
23 
24 namespace Deveel.Data.Sql.Query {
32  [Serializable]
34  public SimpleSelectNode(IQueryPlanNode child, ObjectName columnName, SqlExpressionType op, SqlExpression expression)
35  : base(child) {
36  ColumnName = columnName;
37  OperatorType = op;
38  Expression = expression;
39  }
40 
42  : base(data) {
43  ColumnName = data.GetValue<ObjectName>("Column");
44  OperatorType = (SqlExpressionType) data.GetInt32("Operator");
45  Expression = data.GetValue<SqlExpression>("Expression");
46  }
47 
48  public ObjectName ColumnName { get; private set; }
49 
50  public SqlExpressionType OperatorType { get; private set; }
51 
52  public SqlExpression Expression { get; private set; }
53 
54  protected override void GetData(SerializeData data) {
55  data.SetValue("Column", ColumnName);
56  data.SetValue("Operator", (int)OperatorType);
57  data.SetValue("Expression", Expression);
58  }
59 
60  public override ITable Evaluate(IRequest context) {
61  // Solve the child branch result
62  var table = Child.Evaluate(context);
63 
64  // The select operation.
65  return table.SimpleSelect(context, ColumnName, OperatorType, Expression);
66  }
67  }
68 }
Defines the contract to access the data contained into a table of a database.
Definition: ITable.cs:40
A IQueryPlanNode with a single child.
override void GetData(SerializeData data)
void SetValue(string key, Type type, object value)
Describes the name of an object within a database.
Definition: ObjectName.cs:44
SqlExpressionType
All the possible type of SqlExpression supported
A node element of a query plan tree. /summary>
The node for performing a simple select operation on a table.
override ITable Evaluate(IRequest context)
SimpleSelectNode(IQueryPlanNode child, ObjectName columnName, SqlExpressionType op, SqlExpression expression)
Defines the base class for instances that represent SQL expression tree nodes.