linq数据分组groupby
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(
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];
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论