|
Можно ли впихнуть в LINQ to SQL сложную конструкцию с проверкой результата SUM()?
|
|||
---|---|---|---|
#18+
У меня есть C# приложение. Оно использует EntityFramework.6.2.0 для доступа к базе SQL Server 2012. Мне понадобилось в приложении выполнить через LINQ to SQL следующий запрос: Таблицы используемые запросом: Код: sql 1. 2. 3.
Вторая таблица – дочерняя по отношению к [Work.Work], несколько её строк приходятся на одну строку [Work.Work]: Код: sql 1. 2. 3. 4. 5.
Собственно запрос (на SQL): Код: sql 1. 2. 3. 4. 5. 6.
Мне надо создать на LINQ to SQL аналог этого SQL запроса. У меня пока получилось написать LINQ to SQL конструкцию которая содержит ДВА подзапроса к дочерним строкам [Work.WorkContributor] с вычислением этой SUM(wc.MechanicalShare). Результат первого подзапроса я сравниваю ‘>= 99.9’. Результат второго подзапроса я сравниваю ‘<=100.1’. В результате всё это работает – но в реальном SQL запросе так и вычисляются ДВА подзапроса к дочерним строкам [Work.WorkContributor]. Что будет работать медленно. А как сделать так чтобы LINQ to SQL содержал всего один подзапрос к [Work.WorkContributor]; и чтобы в реальном SQL запросе тоже присутствовал всего один такой подзапрос? ... |
|||
:
Нравится:
Не нравится:
|
|||
07.11.2019, 13:46 |
|
Можно ли впихнуть в LINQ to SQL сложную конструкцию с проверкой результата SUM()?
|
|||
---|---|---|---|
#18+
Дополнение: "У меня пока получилось написать LINQ to SQL конструкцию которая содержит ДВА подзапроса к дочерним строкам" - вот она: Код: c# 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19.
Yes, it works – but a real SQL query to the DB has TWO separate sub-queries to [Work.WorkContributor]. It will work slow. Here is the real SQL query: Код: sql 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19.
... |
|||
:
Нравится:
Не нравится:
|
|||
07.11.2019, 14:46 |
|
|
start [/forum/topic.php?fid=17&fpage=3&tid=1349097]: |
0ms |
get settings: |
10ms |
get forum list: |
12ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
28ms |
get topic data: |
13ms |
get forum data: |
3ms |
get page messages: |
36ms |
get tp. blocked users: |
2ms |
others: | 13ms |
total: | 125ms |
0 / 0 |