本文整理汇总了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");
}
示例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");
}
示例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");
}
示例4: GetAsVariableRef
internal static Variable GetAsVariableRef(Expression op)
{
if (op.Type == ExpressionType.FetchVariable) {
return (Variable)op.GetArgument("var");
}
return null;
}
示例5: GetStaticString
public static string GetStaticString(Expression expression)
{
FetchStaticExpression staticExp = (FetchStaticExpression) expression.GetArgument("arg0");
return staticExp.Value;
}
示例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");
}
示例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();
}
示例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;
}
示例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);
}
}
示例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));
}
}
示例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(" ");
}
}
示例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;
}
示例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");
//.........这里部分代码省略.........
示例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);
}
//.........这里部分代码省略.........
示例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);
}