本文整理汇总了C#中System.Linq.Expressions.MethodCallExpression.Invoke方法的典型用法代码示例。如果您正苦于以下问题:C# MethodCallExpression.Invoke方法的具体用法?C# MethodCallExpression.Invoke怎么用?C# MethodCallExpression.Invoke使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类System.Linq.Expressions.MethodCallExpression
的用法示例。
在下文中一共展示了MethodCallExpression.Invoke方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: VisitMethodCall
protected override Expression VisitMethodCall(MethodCallExpression m)
{
if (m.Method.Name == "Where")
{
_sql.Append(" WHERE ");
SheetType = m.Type.GetGenericArguments()[0];
ReturnType = SheetType;
this.Visit(m.Arguments[1]);
}
else if (IsRowMethodCall(m))
{
if (m.Object.As<MethodCallExpression>().Arguments[0].As<ConstantExpression>().Type == typeof(int))
throw new ArgumentException("Cannot use column indexes in where clause");
string columnName = m.Object.As<MethodCallExpression>().Arguments[0].As<ConstantExpression>().Value.ToString();
_sql.Append(string.Format("[{0}]", columnName));
}
else if (m.Method.Name == "Select")
{
SheetType = m.Method.GetGenericArguments()[0];
ReturnType = m.Method.GetGenericArguments()[1];
if (m.Arguments[0].NodeType != ExpressionType.Constant)
this.Visit(m.Arguments[0]); //Where clause
NewExp = m.Arguments[1].As<UnaryExpression>().Operand;
}
else
{
object methodObject = ((ConstantExpression)m.Object).Value;
object returnValue = m.Invoke();
_params.Add(new OleDbParameter("?", returnValue));
_sql.Append("?");
}
return m;
}