Использование linq для возврата объекта со списком <object>member - PullRequest
1 голос
/ 06 апреля 2011

Я все еще немного новичок в Linq для 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 взяты из другой таблицы, для которой я также определил класс.

Спасибо всем, у кого есть решение для этого.Помощь очень ценится!

1 Ответ

3 голосов
/ 06 апреля 2011

Это немного сложно, не зная, как соотносятся ваши таблицы, но вы можете сделать это:

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()
                 });
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...