可以在匿名c#方法中使用局部变量,即在以下代码中我只想执行一次计数.
IQueryablelinq = db.Enquiries; if(...) linq = linq.Where(...); if(...) linq = linq.Where(e => (x <= (from p in db.Orders where p.EnquiryId == e.Id select p).Count() && (from p in db.Orders where p.EnquiryId == e.Id select p).Count() <= y)); if(...) linq = linq.Where(...); var result = (from e in linq select e);
匿名函数是否有"让"?
更新:请注意,我在此语句后添加了几个Where子句,因此无法使用select关闭.
/尼尔斯
是的,为什么不?!毕竟它是一个功能,只是匿名!
例:
x => { int y = x + 1; return x + y; }
或者:
delegate(int x) { int y = x + 1; return x + y; }
所以你的代码可以写成:
... = linq.Where(e => { var count = (from p in db.Orders where p.EnquiryId == e.Id select p).Count(); return x <= count && count <= y; });
更新:要澄清有关注释的内容,了解匿名方法和lambda表达式之间的区别非常重要.匿名方法就像普通方法一样,没有明确的名称.编译时,编译器会生成一个带有奇怪名称的普通方法,因此它没有任何特殊限制.但是,匿名方法的一种表示形式是lambda表达式.Lambda表达式可以用几种不同的方式解释.第一个是代表.这样,它们就等于匿名方法.第二个是表达式树.这种方式通常由LINQ to SQL和其他一些LINQ提供程序使用.它们不会以任何方式直接执行您的表达式.它们将其解析为表达式树,并使用树作为输入数据来生成要在服务器上运行的等效SQL语句.它不像方法那样执行,也不被认为是匿名方法.在这种情况下,您无法定义局部变量,因为无法将lambda解析为表达式树.
是的,您可以完全按照自己的意愿,在Linq中使用对象,使用Linq to SQL.
let
Linq中有一个,允许您在查询中间为中间结果命名,就像您想要的那样.根据你的例子:
... = from e in linq let count = (from p in db.Orders where p.EnquiryId == e.Id select p).Count() where (x <= count) && (count <= y) select e;
顺便说一下,我认为你的原始例子在语法上有些错误,当count
它只是一个名字时更容易被发现:
where (x <= count) && /* <= */ (count <= y);