Диаграмма 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
Linq thenInclude и таблица мостов ⇐ C#
Место общения программистов C#
1730912319
Anonymous
[b]Диаграмма ER (приносим извинения за отсутствие навыков работы с блок-схемами)[/b]:
[img]https://i. sstatic.net/f5Ya8yp6.png[/img]
[b]Модели:[/b]
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;}
}
[b]DTO[/b]
Во многом отражает модели. Обратите внимание: меня не особо беспокоит, где появляются объекты 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; }
}
[b]Вот мой запрос:[/b]
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)
[b]Проблема, которую я пытаюсь решить:[/b]
Как видите, запрос дает мне список подобъектов, и каждый из них будет иметь 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]
.
.
.
Подробнее здесь: [url]https://stackoverflow.com/questions/79160477/linq-theninclude-and-bridge-table[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия