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];

猜你喜欢

转载自blog.csdn.net/u010178308/article/details/84336468