Linq thenInclude и таблица мостовC#

Место общения программистов C#
Ответить
Anonymous
 Linq thenInclude и таблица мостов

Сообщение Anonymous »

Диаграмма ER (приносим извинения за отсутствие навыков работы с блок-схемами):
[img]https://i. sstatic.net/f5Ya8yp6.png[/img]

Модели:
public class MainObject
{
public int Id { get; set; }
public ICollection SubObjects{ get; set; } = [];
}

public class SubObject
{
public int Id {get; set;}
public int MainObjectId {get; set;}
public int TableAObjectId {get; set;}
public int TableBObjectId {get; set;}

public TableAObject TableAObject {get; set;}
public TableBObject TableBObject {get; set;}

}

public class TableAObject
{
public int Id {get; set}
public ICollection
BridgeTableObjects { get; set; } = [];

}

public class TableBObject
{
public int Id {get; set}
public ICollection
BridgeTableObjects { get; set; } = [];

}

public class BridgeTableObject
{
public int Id {get; set;}
public int TableAObjectId {get; set;}
public int TableBObjectId {get; set;}

public BridgeTableDetailObject BridgeTableDetailObject {get; set;}

}

public class BridgeTableDetailObject
{
public int Id {get; set;}
}

DTO
Во многом отражает модели. Обратите внимание: меня не особо беспокоит, где появляются объекты BridgeTable; им не обязательно появляться одновременно под объектами TableA и TableB. Но поскольку BridgeTable (как следует из названия и как я упоминал в одном из комментариев ниже, является ссылкой на TableA и Table B, полученные объекты должны это отражать). Я просто не знаю, как составить запрос, чтобы получить это.
public class MainDto
{
public List SubObjects{ get; set; } = [];
}

public class SubObjectDto
{
public TableAObjectDto TableAObjectDto { get; set; }
public TableBObjectDto TableBObjectDto { get; set; }

}

public class TableAObjectDto
{
public List
BridgeTableObjectDto{ get; set; } = [];
}

public class TableBObjectDto
{
}

public class BridgeTableObjectDto
{
public BridgeTableDetailObjectDto BridgeTableDetailObjectDto{ get; set; }
}

Вот мой запрос:
mainObjects.Where(m => m.Id == 1)
.Include(m => m.subObjects)
.ThenInclude(s => s.tableAObject)
.ThenInclude(ta => ta.bridgeTableObjects)
.ThenInclude(bt => bt.bridgeTableDetailObject)
.Include(m => m.subObjects).ThenInclude(s => s.tableBObject)

Проблема, которую я пытаюсь решить:
Как видите, запрос дает мне список подобъектов, и каждый из них будет иметь tableAObject с список BridgeTableObjects.
По сути, запрос преобразуется в соединение только между TableA и BridgeTable, возвращая несколько объектов BridgeTable. Мне также нужно объединить BridgeTable с таблицей B, чтобы я получил один объект BridgeTable. Или, другими словами: для основного объекта с идентификатором = 1 получите список подчиненных объектов, чтобы каждый подчиненный объект (либо через объект TableA, либо через объект TableB) получал одну запись объекта BridgeTable. Возможно ли это с помощью Include/ThenInclude в одном запросе?
Итак, список, который я получаю, должен быть примерно таким, как приведенный ниже, но у меня должен быть только один BridgeTableObject (а не список). Для меня это сложная часть, так как я не могу понять, как мне заставить BridgeTable присоединиться к TableA и TableB в запросе (или я не уверен, возможно ли это вообще).
mainObject
subObject[0]
tableAObject
**bridgeTableObject**
bridgeTableDetailObject
tableBObject
subObject[1]
.
.
.



Подробнее здесь: https://stackoverflow.com/questions/791 ... idge-table
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»