我对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。 Lines的数据来自另一个我已定义类的表。
感谢任何可能为此提供解决方案的人。非常感谢帮助!
答案 0 :(得分:3)
这有点难,不知道你的表格如何相关,但你可以这样做:
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()
});