0

我将此谓词与 EF 和 lamdba 表达式一起使用:

public class PredicateBuilder
{
    public static Expression<Func<T, bool>> True<T>() { return f => true; }
    public static Expression<Func<T, bool>> False<T>() { return f => false; }
}

public static class ExpressionExtensions
{
    public static Expression<Func<T, bool>> And<T>(this Expression<Func<T, bool>> first, Expression<Func<T, bool>> second)
    {
        return first.Compose(second, Expression.And);
    }

    public static Expression<Func<T, bool>> Or<T>(this Expression<Func<T, bool>> first, Expression<Func<T, bool>> second)
    {
        return first.Compose(second, Expression.Or);
    }
}

现在我只想动态构建这个查询:

Query(ufe => (ufe.FilmEtat.filmetat_code == etatString && ufe.user_id == 2) || (ufe.FilmEtat.filmetat_code == etatString && ufe.user_id == 11)).ToList();

我已经尝试过:

var predicate = PredicateBuilder.True<UtilisateurFilmEtat>();
int i = 0;
foreach (int utilisateurId in listUtilisateurId)
{
    if (i == 0)
        predicate = ufe => (ufe.FilmEtat.filmetat_code == etatString && ufe.user_id == utilisateurId);
    else
        predicate.Or(ufe => ufe.FilmEtat.filmetat_code == etatString && ufe.user_id == utilisateurId);

    i++;
}

查询正在运行,但没有返回良好的结果...

我快疯了:(

需要你的帮助。

谢谢

4

1 回答 1

0

您的问题似乎与这个问题非常相似: Linq to SQL how to do "where [column] in (list of values)",尽管不是完全重复的。

我可以看到您正在尝试通过将其他查询与 组合来动态构建查询,||如果您只有一个比较运算符,这就是您想要做的......

相反,这样的事情怎么样:ufe => listUtilisateurId.Contains(ufe.user_id)

于 2012-12-14T19:50:37.297 回答