2

非常感谢leppie:目前我得到了

Expression<Func<vwMailMerge,bool>> whereClause= null;
List<vwMailMerge> mailMergeItems = null;

int personType = mailMergeSettings.PersonType.ToInteger();
if (personType > 0)
{
    whereClause = this.MailMergeWhereClause(whereClause, f => f.MemberTypeId == personType);
}
if (mailMergeSettings.PersonIds != null)
{
    var personIds = mailMergeSettings.PersonIds.ToGuidArray();
    if (personIds != null && personIds.Length > 0)
    {
        var personList = personIds.ToList();
        whereClause = this.MailMergeWhereClause(whereClause, f => personList.Contains(f.UserId));
    }
}

mailMergeItems = this.ObjectContext.vwMailMerges.Where(whereClause).ToList();
private Expression<Func<vwMailMerge, bool>> MailMergeWhereClause(params Expression<Func<vwMailMerge, bool>>[] wheres)
{
    if (wheres.Length == 0)
    {
        return x => true;
    }
    Expression result;   
    if (wheres[0] == null)
    {
        result = wheres[1].Body;
        return Expression.Lambda<Func<vwMailMerge, bool>>(result, wheres[1].Parameters);
    }
    else
    {
        result = wheres[0].Body;
        for (int i = 1; i < wheres.Length; i++)
        {
            result = Expression.And(result, wheres[i].Body);
        }
        return Expression.Lambda<Func<vwMailMerge, bool>>(result, wheres[0].Parameters);
        }     
    }
}

当它到达“mailMergeItems =”时,它会掉线并给出错误:“参数'f'未绑定在指定的LINQ to Entities查询表达式中。”

我注意到,当仅检查人员或仅检查 membertypeId 时,它可以正常工作..但结合第二个错误,我认为它是“f =>”。

4

2 回答 2

2

你不能用Func,你需要用Expression<Func>

+可以通过Expression.And.

更新(未测试):

Expression<Func<vwMailMerge, bool>> whereClause = null;
...
Expression<Func<vwMailMerge, bool>> MailMergeWhereClause(
   params Expression<Func<vwMailMerge, bool>>[] wheres)
{
  if (wheres.Length == 0) return x => true;
  Expression result = wheres[0].Body;
  for (int i = 1; i < wheres.Length; i++)
  {
    //probaby needs a parameter fixup, exercise for reader
    result = Expression.And(result, wheres[i].Body); 
  }
  return Expression.Lambda<Func<vwMailMerge,bool>>(result, wheres[0].Parameters);
}

更新 2:

正如我所料,上述方法失败了。ExpressionVistor使用该类在 .NET 4 上可能很容易解决。对于 .NET 3.5(或者如果前面提到的太难了),以下应该可以工作。

该方法是IQueryable直接附加 where 子句,因此您最终得到:

somequery.Where(x => x.foo).Where(x => x.bar).Where(x => x.baz)

IOW,您可以根据需要添加它们,但这需要对您粘贴的代码的逻辑/流程进行一些更改。

于 2011-01-07T11:20:52.260 回答
0

您可以使用代码工具更好地重新格式化您的问题。

但是,您似乎可以通过这种方式解决问题,以避免所有这些 func 表达式四处飘荡:

this.ObjectContext.vwMailMerges.Where(mm=>IsValidMailMerge(mm,personType)).ToList()


private bool IsValidMailMerge(YourType mailmerge, YourType2 personType)
{
if(...) // type specific criteria here
return true;
else
return false;
}
于 2011-01-07T11:24:27.250 回答