我正在尝试手动编写这个linq句子:
item => !item.Matches.Any(m => m.MarketPlace == "Amazon");
我知道调用Any方法,但如何执行相反的操作?
...
...
var anyCall = Expression.Call(typeof(Enumerable), "Any", new[] { modelType }, models, lambdaExp);
return Expression.Lambda<Func<T, bool>>(anyCall, item);
此代码sql输出"Exists"。如何sql输出"不存在"?
在这种情况下,反向会让我想到重新排序。如果你想否定一个表达式,你可以这样做:
var trueExpression = Expression.Constant(true);
var falseExpression = Expression.Not(trueExpression);
在调试视图中,falseExpression
是!True
。
回答您的问题:
var noneCall = Expression.Not(Expression.Call(typeof(Enumerable), "Any", new[] { modelType }, models, lambdaExp));
应该做到这一点。