linq 数据分组group by

var results = from p in persons
              group p.car by p.PersonId into g
              select new { PersonId = g.Key, Cars = g.ToList() };

linq在数据分组时,不会像数据库group by那样,表面上只返回group by后的一条数据,而是根据要分组的条件,把数据汇聚成一个字典,字典的键为分组的条件,字典的值是一个数组,包含所有满足分组条件的数据。

另一种非查询写法:

var results = persons.GroupBy(
    p => p.PersonId, 
    p => p.car,
    (key, g) => new { PersonId = key, Cars = g.ToList() });

使用lookup

var carsByPersonId = persons.ToLookup(p => p.PersonId, p => p.car);
var carsForPerson = carsByPersonId[personId];
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值