我正在为我的一个核心L2S类建立一个函数库,所有这些函数都返回一个bool来允许检查某些情况.
例:
Expression<Func<Account,bool>> IsSomethingX = a => a.AccountSupplementary != null && a.AccountSupplementary.SomethingXFlag != null && a.AccountSupplementary.SomethingXFlag.Value;
现在查询哪里不正确,我不能这样做:
var myAccounts= context.Accounts .Where(!IsSomethingX); // does not compile
但是,使用PredicateBuilder类的语法,我已经提出:
public static IQueryable<T> WhereNot<T>(this IQueryable<T> items,Expression<Func<T,bool>> expr1) { var invokedExpr = Expression.Invoke(expr1,expr1.Parameters.Cast<Expression>()); return items.Where(Expression.Lambda<Func<T,bool>> (Expression.Not(invokedExpr),expr1.Parameters)); } var myAccounts= context.Accounts .WhereNot(IsSomethingX); // does compile
这实际上产生了正确的sql.
这看起来像一个很好的解决方案,有什么我需要知道的,可能会导致我的问题在未来?