在我的存储库实现中,我可以使用lambda表达式运行以下查询:
public IList<User> GetUsersFromCountry(string)
{
return _UserRepository.Where(x => x.Country == "Sweden").ToList();
}
到目前为止,一切都很好,很简单。但是,我很难针对嵌套的->嵌套列表编写lambda表达式。给出下面的例子(对不起,我想不出更好的例子了):
下面的查询可以很好地工作,并返回成员年龄超过45岁的所有俱乐部
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编写上面的查询?
发布于 2009-10-27 04:41:14
这可能会起作用(未经测试)...
var clubs = ClubRepository.Where(c=>c.MemberShips.Any(m=>m.User.Age > 45));
发布于 2009-10-27 04:50:55
这里有一种方法:
var clubs = clubRepository
.SelectMany(c => c.Memberships, (c, m) => new { c, m })
.Where(x => x.m.User.Age > 45)
.Select(x => x.c);
发布于 2021-04-09 15:21:37
一种更通用的方式
List<T> list= new List<T>();
list= object1.NestedList1.SelectMany(x => x.NestedList2).ToList();
其中NestedList2与"list“的数据类型匹配
https://stackoverflow.com/questions/1627170
复制相似问题