从作用域引用的类型'System.Data.DataRow'变量,但未定义



我正在尝试构建通用函数以在DataRows上应用规则。

但是我在运行程序时遇到以下错误

这是我的代码。

public Func<T, bool> CompileRuleDataRow<T>(Rule r)
{
    var paramUser = Expression.Parameter(typeof(T));
    Expression expr = BuildExprDataRow<T>(r, paramUser);
    // build a lambda function User->bool and compile it
    //Expression.Lambda<Func<T, bool>>(
    return Expression.Lambda<Func<T, bool>>(expr, paramUser).Compile();
}

用于构建表达式的函数。

public Expression BuildExprDataRow<T>(Rule r, ParameterExpression param)
{
    ParameterExpression objExpr = Expression.Parameter(typeof(string));
    string defaultMember = "Item";
    ConstantExpression indexExpr = Expression.Constant(r.MemberName);
    Expression leftIndexAccessExpr = Expression.Property(objExpr, defaultMember, indexExpr);
    ExpressionType tBinary;
    // is the operator a known .NET operator?
    ExpressionType.TryParse(r.Operator, out tBinary);
    var right = Expression.Constant(r.TargetValue);
    // use a binary operation, e.g. 'Equal' -> 'u.Age == 15'
    return Expression.MakeBinary(tBinary, leftIndexAccessExpr, right);
}

我在主方法中以这种方式调用它。

var rule = new Rule("Name", "Equal", "3");
Func<DataRow, bool> compiledRuleDataRow = CompileRuleDataRow<DataRow>(rule);
DataTable dt = new DataTable();
dt.Columns.Add("Id");
dt.Columns.Add("Name");
dt.Columns.Add("Address");
for (int i = 0; i < 100000; i++)
{
  dt.Rows.Add(i.ToString(), i.ToString(), i.ToString());
}
//I want to do something like this.
    DataRow[] drFiltered = dt.Select().Where(r => compiledRuleDataRow(r)).ToArray();

下面是我的Rule

public class Rule
{
  public string MemberName { get; set; }
  public string Operator { get; set; }
  public string TargetValue { get; set; }
  public Rule(string MemberName, string Operator, string TargetValue)
  {
    this.MemberName = MemberName;
    this.Operator = Operator;
    this.TargetValue = TargetValue;
  }
}

当我运行此代码时,我收到以下错误。

从作用域 '' 引用的类型为 'System.Data.DataRow' 的变量 '', 但它没有定义

说明:执行 当前 Web 请求。请查看堆栈跟踪以获取更多信息 有关错误及其在代码中起源位置的信息。

异常

详细信息:系统无效操作异常:变量 '' 的 从作用域"引用的类型"系统.数据.数据行",但它不是 定义

有人可以帮我吗?

像@svick一样,我收到的错误与发布的代码不同。

无论如何,这种BuildExprDataRow方法有两个问题。首先,它没有使用传递的param参数。其次,属性值未正确转换,因此二进制运算符不起作用。

这是固定方法:

public Expression BuildExprDataRow<T>(Rule r, ParameterExpression param)
{
    var right = Expression.Constant(r.TargetValue);
    var left = Expression.Convert(
        Expression.Property(param, "Item", Expression.Constant(r.MemberName)),
        right.Type);
    var comparison = (ExpressionType)Enum.Parse(typeof(ExpressionType), r.Operator);
    return Expression.MakeBinary(comparison, left, right);
}

顺便说一句,泛型参数T在该方法中也没有使用,因此您可以将其删除(使该方法非泛型)。

最新更新