首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >LazyList上的.where不工作

LazyList上的.where不工作
EN

Stack Overflow用户
提问于 2009-02-27 08:43:42
回答 2查看 232关注 0票数 0

我正在使用Rob的LazyList实现,它工作得很好。

但是,我无法在LazyList类型的子实体上使用.where子句。

例如。就像这样

代码语言:javascript
复制
var qry = orderRepository.GetOrders();
qry = from p in qry where p.Items.Where(t => t.Name == "test") select p;

生成以下编译时错误:

代码语言:javascript
复制
Cannot implicitly convert type 'System.Collections.Generic.IEnumerable<Items>' to 'bool'

查询子实体的正确方式是什么?

EN

回答 2

Stack Overflow用户

发布于 2009-02-27 09:00:12

你需要Any

代码语言:javascript
复制
var qry = orderRepository.GetOrders();
qry = from p in qry where p.Items.Any(t => t.Name == "test") select p;

您已经有了一个where子句,使用第二个子句不会有任何好处。第一个.Where (小写的)希望布尔值能够执行过滤,但您提供的是IEnumerable<Items> (因为这是第二个where返回的内容)。Any的工作方式与Where相同,但是只要至少有一项与您指定的查询匹配,就会返回一个布尔值。

票数 1
EN

Stack Overflow用户

发布于 2009-02-27 08:57:20

我不确定你想通过这句话达到什么目的。

如果您希望所有订单都具有名称为"test“的项目,则使用:

代码语言:javascript
复制
var qry = orderRepository.GetOrders();
qry = from p in qry where p.Items.Any(t => t.Name == "test") select p;

如果您想要名为"test“的所有项,则使用:

代码语言:javascript
复制
var qry = orderRepository.GetOrders();
qry = from p in qry select p.Items.Where(t => t.Name == "test");
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/593998

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档