当前位置: 首页>>代码示例>>C#>>正文


C# Expression.GetArgument方法代码示例

本文整理汇总了C#中Deveel.Data.Sql.Expression.GetArgument方法的典型用法代码示例。如果您正苦于以下问题:C# Expression.GetArgument方法的具体用法?C# Expression.GetArgument怎么用?C# Expression.GetArgument使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Deveel.Data.Sql.Expression的用法示例。


在下文中一共展示了Expression.GetArgument方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: GetActionString

 private static string GetActionString(Expression expression)
 {
     if (expression is FetchStaticExpression) {
         SqlObject val = (SqlObject)expression.GetArgument("static");
         return val.ToString();
     }
     throw new ApplicationException("Expecting static expression");
 }
开发者ID:ikvm,项目名称:deveelsql,代码行数:8,代码来源:SqlInterpreter_DDL.cs

示例2: IsDeferred

        private static bool IsDeferred(Expression expression)
        {
            if (expression is FetchStaticExpression) {
                SqlObject val = (SqlObject)expression.GetArgument("static");
                string str = val.ToString();
                if (str.Equals("initially deferred"))
                    return true;
                if (str.Equals("initially immediate"))
                    return false;

                throw new ApplicationException("Unexpected initial check type '" + str + "'");
            }

            throw new ApplicationException("Expecting static expression");
        }
开发者ID:ikvm,项目名称:deveelsql,代码行数:15,代码来源:SqlInterpreter_DDL.cs

示例3: IsDeferrable

        private static bool IsDeferrable(Expression op)
        {
            if (op is FetchStaticExpression) {
                SqlObject val = (SqlObject)op.GetArgument("static");
                string str = val.ToString();
                if (str.Equals("deferrable"))
                    return true;
                if (str.Equals("not deferrable"))
                    return false;

                throw new ApplicationException("Unexpected deferrability type '" + str + "'");
            }

            throw new ApplicationException("Expecting static expression");
        }
开发者ID:ikvm,项目名称:deveelsql,代码行数:15,代码来源:SqlInterpreter_DDL.cs

示例4: GetAsVariableRef

 internal static Variable GetAsVariableRef(Expression op)
 {
     if (op.Type == ExpressionType.FetchVariable) {
         return (Variable)op.GetArgument("var");
     }
     return null;
 }
开发者ID:ikvm,项目名称:deveelsql,代码行数:7,代码来源:QueryProcessor.cs

示例5: GetStaticString

 public static string GetStaticString(Expression expression)
 {
     FetchStaticExpression staticExp = (FetchStaticExpression) expression.GetArgument("arg0");
     return staticExp.Value;
 }
开发者ID:ikvm,项目名称:deveelsql,代码行数:5,代码来源:SqlInterpreter.cs

示例6: GetTableName

        private TableName GetTableName(Expression exp, int n)
        {
            Expression tname_op = (Expression)exp.GetArgument("arg" + n);
            if (tname_op.Type == ExpressionType.FetchTable)
                throw new ApplicationException("No FETCHTABLE expression at param " + n);

            return (TableName)tname_op.GetArgument("name");
        }
开发者ID:ikvm,项目名称:deveelsql,代码行数:8,代码来源:SqlInterpreter.cs

示例7: Execute

        public ITable Execute(Query query, Expression expression)
        {
            // Create the QueryProcessor
            QueryProcessor processor = new QueryProcessor(transaction);

            // If it's a select,
            if (expression is SelectExpression) {
                QueryOptimizer optimizer = new QueryOptimizer(transaction);
                expression = optimizer.SubstituteParameters(expression, query);
                expression = optimizer.Qualify(expression);
                expression = optimizer.Optimize(expression);

                // Execute the query,
                return processor.Execute(expression);
            }

            // Set the parameter as the base table, and the base rowid (the
            // parameters table only has 1 row).
            processor.PushTable(new QueryParametersTable(query));
            processor.UpdateTableRow(new RowId(0));

            // Otherwise it must be an interpretable function

            if (expression is FunctionExpression) {
                string fun_name = (string)expression.GetArgument("name");

                if (fun_name.Equals("create_table"))
                    return CreateTable(expression);
                /*
                TODO:
                if (fun_name.Equals("drop_table"))
                    return DropTable(processor, expression);
                if (fun_name.Equals("create_index"))
                    return CreateIndex(processor, expression);
                if (fun_name.Equals("drop_index"))
                    return DropIndex(processor, expression);
                if (fun_name.Equals("explain_expression"))
                    return ExplainExpression(expression);
                */
            }

            throw new NotSupportedException();
        }
开发者ID:ikvm,项目名称:deveelsql,代码行数:43,代码来源:SqlInterpreter.cs

示例8: NormalizeReferences

        private Expression NormalizeReferences(Expression op)
        {
            // Assert the operator is qualified
            if (op.GetArgument("qualified") == null)
                throw new ApplicationException("Operator is not qualified.");

            // Perform the normalization

            op = WalkGraph(op, new ReferenceQualifier(this));

            // Mark up that we have successfully normalized the all
            // definitions/references
            op.SetArgument("normalized_def", true);
            return op;
        }
开发者ID:ikvm,项目名称:deveelsql,代码行数:15,代码来源:QueryOptimizer.cs

示例9: InspectParamList

 private static void InspectParamList(IGraphInspector inspector, Expression op, string size_arg, string pre_arg)
 {
     int sz = (int)op.GetArgument(size_arg);
     for (int i = 0; i < sz; ++i) {
         InspectParam(inspector, op, pre_arg + i);
     }
 }
开发者ID:ikvm,项目名称:deveelsql,代码行数:7,代码来源:QueryOptimizer.cs

示例10: InspectParam

 private static void InspectParam(IGraphInspector inspector, Expression expression, string paramArg)
 {
     object paramVal = expression.GetArgument(paramArg);
     if (paramVal != null && paramVal is Expression) {
         Expression inspected = paramVal as Expression;
         expression.SetArgument(paramArg, WalkGraph(inspected, inspector));
     }
 }
开发者ID:ikvm,项目名称:deveelsql,代码行数:8,代码来源:QueryOptimizer.cs

示例11: AppendReturnType

 internal static void AppendReturnType(StringBuilder sb, Expression exp)
 {
     object returnType = exp.GetArgument("return_type");
     if (returnType != null) {
         sb.Append(returnType.ToString());
         sb.Append(" ");
     }
 }
开发者ID:ikvm,项目名称:deveelsql,代码行数:8,代码来源:Expression.cs

示例12: AttemptRangeSetMerge

        private static bool AttemptRangeSetMerge(Variable v, FunctionExpression rangeSetTerm, Expression toMergeWith, string logicalOpName)
        {
            if (toMergeWith is FunctionExpression) {
                FunctionExpression functionExp = (FunctionExpression) toMergeWith;

                // If the type is the same logical operation, we recurse
                string funType = functionExp.Name;
                if (funType.Equals(logicalOpName)) {
                    // Recurse condition, we try left and right merge
                    // We attempt left and right param
                    if (AttemptRangeSetMerge(v, rangeSetTerm, (Expression)functionExp.Parameters[0], logicalOpName))
                        return true;

                    return AttemptRangeSetMerge(v, rangeSetTerm, (Expression) functionExp.Parameters[1], logicalOpName);
                }

                // If it's a range set,
                if (funType.Equals("range_set")) {
                    // Get the var
                    Variable targetVariable = ((FetchVariableExpression) functionExp.Parameters[0]).Variable;

                    // If they match, we merge
                    if (v.Equals(targetVariable)) {
                        // Get the range sets
                        SelectableRange rangeSet1 = (SelectableRange) functionExp.Parameters[1];
                        SelectableRange rangeSet2 = (SelectableRange) rangeSetTerm.Parameters[1];
                        // Make sure the range types are the same
                        SqlObject[] ob1 = (SqlObject[])toMergeWith.GetArgument("full_range_object");
                        SqlObject[] ob2 = (SqlObject[])rangeSetTerm.GetArgument("full_range_object");

                        if (ob1.Length != 1 || ob2.Length != 1)
                            // PENDING: Handle composite terms,
                            return false;

                        SqlType rs1Type = ob1[0].Type;
                        SqlType rs2Type = ob2[0].Type;
                        if (!rs1Type.Equals(rs2Type))
                            // Types are not strictly comparable, therefore can't merge,
                            return false;

                        // Merge (note that range_set1 which is part of 'to_merge_with'
                        // will be modified).
                        if (logicalOpName.Equals("@and_sql")) {
                            // intersect (and)
                            rangeSet1 = rangeSet1.Intersect(rangeSet2);
                        } else {
                            // union (or)
                            rangeSet1 = rangeSet1.Union(rangeSet2);
                        }
                        // Update the simplified term,
                        functionExp.Parameters[1] = rangeSet1;
                        return true;
                    }
                    // Not equal variables so return false
                    return false;
                }

                // fun_type isn't named "range_set", "or" or "and" so we return false
                // indicating no merge is possible.
                return false;
            }

            return false;
        }
开发者ID:ikvm,项目名称:deveelsql,代码行数:64,代码来源:QueryPlanner.cs

示例13: AddTableConstraint

        private void AddTableConstraint(QueryOptimizer optimizer, TableName tableName, Expression constraint)
        {
            // The id of the table we are adding this constraint for
            long table_id = transaction.GetTableId(tableName);

            // The name of the constraint or null if no label defined for the
            // constraint.
            string constraint_name = (string)constraint.GetArgument("constraint_name");
            // The constraint function type
            string constraint_fun_type = (string)constraint.GetArgument("name");

            // If it's a primary key constraint,
            if (constraint_fun_type.Equals("constraint_primary_key")) {
                // The basic var list
                Expression var_list = (Expression) constraint.GetArgument("arg0");
                // Constraint check control
                Expression deferrability = (Expression) constraint.GetArgument("arg1");
                Expression init_check = (Expression) constraint.GetArgument("arg2");

                // Make sure the var list qualifies
                var_list = optimizer.QualifyAgainstTable(var_list, tableName);

                // Check a primary key isn't already defined
                IDbCommand command = CreateDbCommand(
                     " SELECT * \n " +
                     "   FROM " + SystemTableNames.ConstraintsUnique + " \n" +
                     "  WHERE object_id = ? \n" +
                     "    AND primary_key = true \n");

                command.Parameters.Add(tableName.Schema);
                command.Parameters.Add(tableName.Name);

                IDataReader result = command.ExecuteReader();
                // Already a primary key defined on the object
                if (result.Read())
                    throw new ApplicationException("PRIMARY KEY constraint already defined on " + tableName);

                // Update the table
                QueryResult uTable = TableUpdatable(SystemTableNames.ConstraintsUnique);
                uTable.BeginInsertRow();
                uTable.Update("table_schema", tableName.Schema);
                uTable.Update("table_name", tableName.Name);
                uTable.Update("name", constraint_name);
                uTable.Update("deferred", IsDeferred(init_check));
                uTable.Update("deferrable", IsDeferrable(deferrability));
                uTable.Update("primary_key", true);
                uTable.InsertRow();

                // Add the var list to the column set
                AddToConstraintColumns(tableName, constraint_name, var_list, null);
            }
                // If it's a foreign key constraint,
            else if (constraint_fun_type.Equals("constraint_foreign_key")) {
                // The var list
                Expression var_list = (Expression) constraint.GetArgument("arg0");
                // The table the foreign key references
                Expression ref_table = (Expression) constraint.GetArgument("arg1");
                // Either 6 or 7 parameters
                int param_count = (int)constraint.GetArgument("param_count");
                // The var list on the referenced table
                Expression foreign_var_list;
                int n;
                if (param_count == 6) {
                    n = 2;
                    foreign_var_list = null;
                } else if (param_count == 7) {
                    n = 3;
                    foreign_var_list = (Expression) constraint.GetArgument("arg2");
                } else {
                    throw new ApplicationException("Unexpected parameter count");
                }

                // Trigger actions
                Expression updateAction = (Expression) constraint.GetArgument("arg" + n + 0);
                Expression deleteAction = (Expression) constraint.GetArgument("arg" + n + 1);
                // Constraint check control
                Expression deferrability = (Expression) constraint.GetArgument("arg" + n + 2);
                Expression init_check = (Expression) constraint.GetArgument("arg" + n + 3);

                // Make sure the var list qualifies
                var_list = optimizer.QualifyAgainstTable(var_list, tableName);
                // Qualify the reference table
                ref_table = optimizer.Qualify(ref_table);
                TableName refTableName = (TableName) ref_table.GetArgument("name");

                // Walk the table reference graph and ensure no table is visited more
                // than once (there are no circular dependancies created).
                List<TableName> table_set = new List<TableName>();
                table_set.Add(tableName);
                CheckNoCircularDependancy(table_set, refTableName);

                // The number of parameters in the foreign key
                int var_param_count = (int)var_list.GetArgument("param_count");
                // If there's a foreign variable list
                if (foreign_var_list != null) {
                    // Qualify it against the reference table
                    foreign_var_list = optimizer.QualifyAgainstTable(foreign_var_list, refTableName);
                    // Check the number of keys are equal
                    if (((int)foreign_var_list.GetArgument("param_count")) != var_param_count) {
                        throw new ApplicationException("Key element count mismatch in FOREIGN KEY constraint");
//.........这里部分代码省略.........
开发者ID:ikvm,项目名称:deveelsql,代码行数:101,代码来源:SqlInterpreter_DDL.cs

示例14: CreateTable

        private ITable CreateTable(Expression expression)
        {
            // create_table has the following arguments,
            //   ( table_name, declarations (columns and constraints),
            //     [ check_expression ] )

            // The table name
            TableName tableName = (TableName)((Expression)expression.GetArgument("arg0")).GetArgument("name");
            tableName = QualifyTableName(tableName);

            // Does the table exist already?
            if (transaction.TableExists(tableName)) {
                // If the 'if_not_exists' argument is present, we don't generate an
                // error, simply returning '0'.  Otherwise we generate an error.
                if (expression.GetArgument("if_not_exists") != null)
                    return DMLResult(0);

                // Otherwise generate an exception
                throw new ApplicationException("Table '" + tableName + "' already exists");
            }

            // We aren't allowed to create tables in the system schema
            if (tableName.Schema.Equals(SystemTableNames.SystemSchema)) {
                throw new ApplicationException("Unable to create table in the " + SystemTableNames.SystemSchema + " schema");
            }

            // The declarations op
            Expression declarations = (Expression)expression.GetArgument("arg1");

            // An optimizer for qualifying operations
            QueryOptimizer optimizer = new QueryOptimizer(transaction);

            // Split out the column declarations
            List<Expression> columnDeclares = new List<Expression>();
            List<Expression> constraintDeclares = new List<Expression>();
            int arg_count = (int)declarations.GetArgument("param_count");
            for (int i = 0; i < arg_count; ++i) {
                Expression decl = (Expression)declarations.GetArgument("arg" + i);
                // Is this a column declaration?
                if (decl.GetArgument("name").Equals("column_declaration")) {
                    columnDeclares.Add(decl);
                } else {
                    constraintDeclares.Add(decl);
                }
            }

            // Create the table
            SystemTable table = transaction.CreateTable(tableName);
            try {
                // For each column declare
                foreach (Expression col in columnDeclares) {
                    // Column name
                    Variable colName = (Variable)((Expression)col.GetArgument("arg0")).GetArgument("var");
                    if (colName.TableName != null &&
                        !colName.TableName.Equals(tableName)) {
                        throw new ApplicationException("Invalid column name " + colName);
                    }

                    // Declared type
                    SqlType colType = (SqlType)col.GetArgument("arg1");
                    // Does the column have a default expression?
                    Expression defaultExpr = null;
                    int n = 2;
                    if (col.GetArgument("has_default_exp") != null) {
                        defaultExpr = (Expression)col.GetArgument("arg2");
                        ++n;
                    }
                    // Any remaining arguments will be constraints
                    bool notNull = false;
                    bool unique = false;
                    while (true) {
                        Expression cons = (Expression)col.GetArgument("arg" + n);
                        if (cons == null)
                            break;

                        SqlObject constraint = (SqlObject)cons.GetArgument("static");
                        string constraint_str = constraint.ToString();
                        if (constraint_str.Equals("NOT NULL")) {
                            notNull = true;
                        } else if (constraint_str.Equals("NULL")) {
                            notNull = false;
                        } else if (constraint_str.Equals("UNIQUE")) {
                            unique = true;
                        } else {
                            throw new ApplicationException("Unknown column constraint '" + constraint_str + "'");
                        }
                        ++n;
                    }

                    // If we have a unique constraint, add it to the constraint list
                    if (unique) {
                        FunctionExpression uniqueConstraint = new FunctionExpression("constraint_unique");
                        FunctionExpression basic_ref = new FunctionExpression("basic_var_list");
                        basic_ref.Parameters.Add(new FetchVariableExpression(colName));
                        uniqueConstraint.Parameters.Add(basic_ref);
                        uniqueConstraint.Parameters.Add(new FetchStaticExpression("deferrable"));
                        uniqueConstraint.Parameters.Add(new FetchStaticExpression("initially immediate"));
                        constraintDeclares.Add(uniqueConstraint);
                    }

//.........这里部分代码省略.........
开发者ID:ikvm,项目名称:deveelsql,代码行数:101,代码来源:SqlInterpreter_DDL.cs

示例15: AddToConstraintColumns

        private void AddToConstraintColumns(TableName tableName, string constraintName, Expression expression, string columnType)
        {
            // Convert the list to an array of strings for each column name
            int varListCount = (int)expression.GetArgument("param_count");
            List<string> colNames = new List<string>(varListCount);
            for (int i = 0; i < varListCount; ++i) {
                // Get the var
                Expression var = (Expression)expression.GetArgument("arg" + i);
                Variable v = (Variable)var.GetArgument("var");
                // Add to the list
                colNames.Add(v.Name);
            }

            AddToConstraintColumns(tableName, constraintName, colNames, columnType);
        }
开发者ID:ikvm,项目名称:deveelsql,代码行数:15,代码来源:SqlInterpreter_DDL.cs


注:本文中的Deveel.Data.Sql.Expression.GetArgument方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。