表达式调用任何方法反转
Expression Call Any Method Reverse
我正在尝试手动编写这个 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 输出 'Not Exists' ?
在这种情况下,reverse 让我想到了重新排序。如果你想否定一个表达式,你可以这样做:
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));
应该可以解决问题。
我正在尝试手动编写这个 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 输出 'Not Exists' ?
在这种情况下,reverse 让我想到了重新排序。如果你想否定一个表达式,你可以这样做:
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));
应该可以解决问题。