c# - 使用 linq 返回带有 list<object> 成员的对象

标签 c# linq linq-to-sql

我对 Linq to SQL 还有些陌生。我正在寻找一种通过使用单个 linq 查询来获取对象的所有成员的方法。我遇到的问题是类成员之一是自定义对象的列表。事情是这样的:

类(class):

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。 Lines 的数据来自另一个表,我也为其定义了一个类。

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

最佳答案

这有点困难,不知道你的表如何关联,但你可以这样做:

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()
                 });

关于c# - 使用 linq 返回带有 list<object> 成员的对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5558144/

相关文章:

c# - Visual Studio 2013 中的自定义 "One ASP.NET"项目模板

c# - 如何从 Newtonsoft.Json (C#) 访问嵌套的 JSON 对象?

c# - 转换 linq-to-sql 的结果

c# - 如何使用 Linq 查找列表中不存在于另一个列表中的元素?

c# - 通过业务逻辑初始化 Linq to Sql 对象

c# - 没有 DataMember 属性的 DataContract 序列化

c# - 为什么我的 SharpZipLib ZipEntry.Comment 没有设置(或读取)?

c# - ThreadPool 或 Task 是否适合用于服务器?

c# - CreateDocumentQuery 与 LINQ 一起使用时会引发异常,与 SQL 一起使用时则正常

C# WebApi重构选择Linq