使用linq返回一个带有list的对象成员

本文关键字:对象 list object 成员 返回 linq 一个 使用 | 更新日期: 2023-09-27 17:48:58

我对Linq to SQL还是有点陌生。我正在寻找一种方法来获得一个对象的所有成员使用一个单一的linq查询。我遇到的问题是,其中一个类成员是一个自定义对象列表。它是这样的:

类:

public class RoomConfiguration
{
    public int ConfigID {get;set;}
    public string ConfigName { get; set; }
    public int RowCount { get; set; }
    public int ColCount { get; set; }
    public int FillDirection { get; set; }
    public string BigDoor { get; set; }
    public string SmallDoor { get; set; }
    public List<LineConfig> Lines { get; set; }
}

我正在寻找一个linq查询,将填写这个类的所有成员,包括行。Lines的数据来自另一个表,我也为它定义了一个类。

感谢任何可能有解决方案的人。非常感谢您的帮助!

使用linq返回一个带有list的对象<object>成员

不知道表之间的关系,这有点困难,但您可以这样做:

var configs = db.RoomConfigurations
                .Select( r => new RoomConfiguration
                 {
                     ConfigID = r.ConfigID,
                     ConfigName = r.ConfigName,
                     ...
                     Lines = db.LineConfigs
                               .Where( l => l.RoomConfigID == r.ConfigID )
                               .ToList()
                 });

var configs = db.RoomConfigurations
                .Join( db.LineConfigs, r => r.ConfigID, l => l.RoomConfigID, (r,l) => new { RoomConfig = r, LineConfigs = l } )
                .GroupBy( j => j.RoomConfig )
                .Select( g => new RoomConfiguration
                 {
                     ConfigID = g.Key.ConfigID,
                     ConfigName = g.Key.ConfigName,
                     ...
                     Lines = g.LineConfigs.ToList()
                 });
相关文章: