DeveelDB  20151217
complete SQL database system, primarly developed for .NET/Mono frameworks
DeclareCursorNode.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 using System.Linq;
20 
21 using Deveel.Data.Sql.Cursors;
24 
25 namespace Deveel.Data.Sql.Parser {
27  public string CursorName { get; private set; }
28 
29  public IExpressionNode QueryExpression { get; private set; }
30 
31  public IEnumerable<CursorParameterNode> Parameters { get; private set; }
32 
33  public bool Insensitive { get; private set; }
34 
35  public bool Scroll { get; private set; }
36 
37  protected override ISqlNode OnChildNode(ISqlNode node) {
38  if (node is IdentifierNode) {
39  CursorName = ((IdentifierNode) node).Text;
40  } else if (node.NodeName.Equals("cursor_args_opt")) {
41  Parameters = node.FindNodes<CursorParameterNode>();
42  } else if (node is IExpressionNode) {
43  QueryExpression = (SqlQueryExpressionNode) node;
44  } else if (node.NodeName.Equals("insensitive_opt")) {
45  Insensitive = node.ChildNodes.Any();
46  } else if (node.NodeName.Equals("scroll_opt")) {
47  Scroll = node.ChildNodes.Any();
48  }
49 
50  return base.OnChildNode(node);
51  }
52 
53  protected override void BuildStatement(StatementBuilder builder) {
54  var parameters = new List<CursorParameter>();
55  if (Parameters != null) {
56  foreach (var parameterNode in Parameters) {
57  var dataType = builder.BuildDataType(parameterNode.ParameterType);
58  parameters.Add(new CursorParameter(parameterNode.ParameterName, dataType));
59  }
60  }
61 
62  var flags = new CursorFlags();
63  if (Insensitive)
64  flags |= CursorFlags.Insensitive;
65  if (Scroll)
66  flags |= CursorFlags.Scroll;
67 
68  var queryExpression = (SqlQueryExpression) ExpressionBuilder.Build(QueryExpression);
69 
70  builder.Statements.Add(new DeclareCursorStatement(CursorName, parameters.ToArray(), flags, queryExpression));
71  }
72  }
73 }
override ISqlNode OnChildNode(ISqlNode node)
During the initialization of the node from the parser, this method is called for every child node add...
This is a simple identifier within a SQL grammar.
Defines the contract for nodes in an AST model for a SQL grammar analysis and parsing.
Definition: ISqlNode.cs:25
string NodeName
Gets the name of the node analyzed from the parser.
Definition: ISqlNode.cs:29
static SqlExpression Build(IExpressionNode node)
ICollection< IStatement > Statements
The root node of an expression used to select a set of items from a set of sources defined...
IEnumerable< ISqlNode > ChildNodes
Gets a read-only enumeration of the children nodes, if any.
Definition: ISqlNode.cs:39
override void BuildStatement(StatementBuilder builder)
SqlType BuildDataType(DataTypeNode node)
This interface acts like a marker that indicates if a ISqlNode represents a SQL expression.