如何声明分组 Linq 查询的返回类型

本文关键字:Linq 查询 返回类型 何声明 声明 | 更新日期: 2023-09-27 18:35:41

以下查询返回的类型是什么:

var photos = job.Photos.GroupBy(x => x.Location)
        .Select(group =>
            new
            {
                Name = group.Key,
                Photos = group.OrderByDescending(x => x.DateAdded)
            })
        .OrderBy(group => group.Name)
        .ToList();       

根据调试器,它的类型是:

'System.Collections.Generic.List<<anonymous type: string Name, System.Linq.IOrderedEnumerable<Project.Models.Photo> Photos>>'

但我不知道如何声明这种类型。

我试过了

public List<string, IOrderedEnumerable<Photo>> Photos {get; set;)

但是列表只能接受一个元素

如何声明分组 Linq 查询的返回类型

使用字典将字符串键和照片列表作为值保存,如果您不想创建另一个类,只需保存此信息即可。

IDictionary<string, List<Photo>> photos = job.Photos.GroupBy(x => x.Location)
        .Select(group =>
            new
            {
                Name = group.Key,
                Photos = group.OrderByDescending(x => x.DateAdded)
            })
        .OrderBy(group => group.Name)
        .ToDictionary(kv=>kv.Name, kv=>kv.Photos.ToList());

您有几个选项:

  • 您可以创建类来保存分组键和与之关联的值集合。并创建该类的实例,而不是匿名类型。
  • 您可以使用Dictionary<TKey, TValue> Value IOrderedEnumerable<T>
var photos = job.Photos
                .GroupBy(x => x.Location)
                .ToDictionary(group => group.Key, 
                              group => group.OrderByDescending(x => x.DateAdded));

我会在OrderByDescending之后添加一个额外的ToList调用,以防止项目只被解析和排序一次。

正如调试器所说,它是一个匿名类型。这意味着你不能写它的名字,因为它没有。您可以做的是创建一个新类并在查询中使用它:

List<PhotosGroup> photos = job.Photos.GroupBy(x => x.Location)
        .Select(group =>
            new PhotosGroup
            {
                Name = group.Key,
                Photos = group.OrderByDescending(x => x.DateAdded)
            })
        .OrderBy(group => group.Name)
        .ToList();

或者您可以使用Tuple类型:

List<Tuple<string, IOrderedEnumerable<Photo>> photos = job.Photos.GroupBy(x => x.Location)
        .Select(group =>
            Tuple.Create(
                group.Key,
                group.OrderByDescending(x => x.DateAdded)))
        .OrderBy(group => group.Item1)
        .ToList();