首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何使用lambda表达式查询嵌套列表

如何使用lambda表达式查询嵌套列表
EN

Stack Overflow用户
提问于 2009-10-27 04:31:43
回答 3查看 31.7K关注 0票数 21

在我的存储库实现中,我可以使用lambda表达式运行以下查询:

代码语言:javascript
复制
public IList<User> GetUsersFromCountry(string)
{
    return _UserRepository.Where(x => x.Country == "Sweden").ToList();                  
}

到目前为止,一切都很好,很简单。但是,我很难针对嵌套的->嵌套列表编写lambda表达式。给出下面的例子(对不起,我想不出更好的例子了):

下面的查询可以很好地工作,并返回成员年龄超过45岁的所有俱乐部

代码语言:javascript
复制
public IList<Clubs> GetGoldMembers()
        {
            var clubs =   from c in ClubRepository
                          from m in c.Memberships 
                          where m.User.Age  >  45
                          select c;

            return clubs;
        }

目前,我对lambda表达式的了解到此为止。

我如何使用与上面的示例类似的lambda表达式,针对ClubRepository编写上面的查询?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2009-10-27 04:41:14

这可能会起作用(未经测试)...

代码语言:javascript
复制
var clubs = ClubRepository.Where(c=>c.MemberShips.Any(m=>m.User.Age > 45));
票数 31
EN

Stack Overflow用户

发布于 2009-10-27 04:50:55

这里有一种方法:

代码语言:javascript
复制
var clubs = clubRepository
    .SelectMany(c => c.Memberships, (c, m) => new { c, m })
    .Where(x => x.m.User.Age > 45)
    .Select(x => x.c);
票数 22
EN

Stack Overflow用户

发布于 2021-04-09 15:21:37

一种更通用的方式

代码语言:javascript
复制
List<T> list= new List<T>();
list= object1.NestedList1.SelectMany(x => x.NestedList2).ToList();

其中NestedList2与"list“的数据类型匹配

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1627170

复制
相关文章

相似问题

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