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


C# Expression.SetArgument方法代码示例

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


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

示例1: 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

示例2: 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

示例3: QualifyAgainstTableList

        public Expression QualifyAgainstTableList(Expression expression, IList<TableName> tableNames)
        {
            // First pass qualifies the table names and expands out the output
            // (globs, etc) on the exit.
            expression = WalkGraph(expression, new TableQualifyInspector(this));

            // Second pass qualifies all remaining references in the query, including
            // forward and backward references in nested queries.

            ExpressionQualifier qualifier = new ExpressionQualifier(this);
            // If there's a base set of tables to qualify the expression against,
            if (tableNames.Count > 0) {
                // Make a var list for all the tables that represent the base
                // qualifications
                List<FetchVariableExpression> varList = new List<FetchVariableExpression>(4);
                foreach (TableName t in tableNames) {
                    PopulateVariables(varList, t);
                }
                // Add the reference set to the qualifier
                qualifier.AddReferences(varList);
            }

            // And qualify
            expression = WalkGraph(expression, qualifier);

            // Third pass, we perform type completion on the SELECT output and
            // functions and verify the functions are correct.
            expression = WalkGraph(expression, new SelectOutputTypeCompletion(this));

            // Fourth pass, check functions,
            expression = WalkGraph(expression, new AllFunctionTypeCompletion(this));

            // Mark up that the expression has successfully qualified,
            expression.SetArgument("qualified", true);

            return expression;
        }
开发者ID:ikvm,项目名称:deveelsql,代码行数:37,代码来源:QueryOptimizer.cs


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