Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
4 / 4 / 1
Регистрация: 15.04.2017
Сообщений: 346

Как выполнить данный запрос SQL В Linq

02.05.2022, 15:28. Показов 484. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Настороне SQL выполняю следующее и все хорошо получается.
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
SELECT * FROM 
 
(SELECT incd.BranchId,incd.ProductId,incd.IncId,incd.NumParty FROM
IncomeDetails incd
INNER JOIN Products prd ON 
incd.BranchId=prd.BranchId AND incd.ProductId=prd.ProductID
INNER JOIN tax tax ON incd.Tax=tax.IdTax
INNER JOIN Sertificate sert ON prd.Sert=sert.IdSert
INNER JOIN Country ctr ON prd.Country=ctr.CountryID
WHERE incd.incid=3) AS i 
LEFT JOIN (SELECT BranchId,ProductId, MAX([DateAdd]) datead
FROM Barcode GROUP BY BranchId,ProductId) br
ON br.BranchId=i.BranchId AND br.ProductId=i.ProductId
LEFT JOIN (SELECT BranchId,ProductId, [DateAdd],Barcode
FROM Barcode) barF ON
br.BranchId=barF.BranchId AND BR.ProductId=barF.ProductId AND BR.datead=barF.[DateAdd]
WHERE i.incid=3
На стороне c# LINQ следующее и выдает ошибку:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
var br = (from bar in db.Barcodes
                          group bar by new { bar.BranchId, bar.ProductId } into g
                          select new { BrId = g.Key.BranchId, PrdId = g.Key.ProductId, Date = g.Max(g => g.DateAdd) }).ToList();
 
                var barF = (from bar in db.Barcodes
                           select new { BrIdF = bar.BranchId, PrdIdF = bar.ProductId, DateF = bar.DateAdd, BarcF = bar.Barcode1 }).ToList();
 
                var incDetO = (from incd in db.IncomeDetails
                               join prd in db.Products on new { incd.BranchId, incd.ProductId } equals new { prd.BranchId, prd.ProductId }
                               join taxx in db.Taxes on incd.Tax equals taxx.IdTax
                               join sertif in db.Sertificates on prd.Sert equals sertif.IdSert
                               join ctr in db.Countries on prd.Country equals ctr.CountryId
                               //join bar in db.Barcodes on new { Br = prd.BranchId, Prd = prd.ProductId } equals new { Br = bar.BranchId, Prd = bar.ProductId }
                               //join barS in br on new { B=bar.BranchId,  P=bar.ProductId,D=bar.DateAdd } equals new { B=barS.BrId, P=barS.PrdId, D=barS.Date }
                               where incd.IncId == Convert.ToInt32(materialTextBoxCode.Text)
                               select new
                               {
                                   NumParty = incd.NumParty,
                                   BranchId = incd.BranchId,
                                   ProductId = incd.ProductId,
                                   PrDescription = prd.ProductDescription,
                                   Qty = incd.Qty,
                                   PriceC = incd.PriceC,
                                   PriceCPlus = incd.PriceCplus,
                                   SumPriceCPlus = incd.SumPriceCplus,
                                   Tax = incd.Tax,
                                   TaxSum = incd.TaxSum,
                                   TotalPrice = incd.TotalPrice,
                                   TotalPriceCur = incd.TotalPriceCur,
                                   Sert = sertif.NumSert,
                                   Prod = incd.Prod
                                   //Bar = bar.Barcode1,
                                   //BrD = bar.DateAdd
                               }).ToArray();
 
                var incDet = (from incdt in incDetO
                              join barcod in br on new { B = incdt.BranchId, P = incdt.ProductId}
                               equals new { B = barcod.BrId, P = barcod.PrdId } into barM
                              from b in barM.DefaultIfEmpty()
                              join barcodF in barF on new { Br = b.BrId, Pr = b.PrdId, Dt = b.Date }
                              equals new { Br = barcodF.BrIdF, Pr = barcodF.PrdIdF, Dt=barcodF.DateF } into barFull
                              from bF in barFull.DefaultIfEmpty()
                              select new
                              {
                                  NumParty = incdt.NumParty,
                                  BranchId = incdt.BranchId,
                                  ProductId = incdt.ProductId,
                                  PrDescription = incdt.PrDescription,
                                  Qty = incdt.Qty,
                                  PriceC = incdt.PriceC,
                                  PriceCPlus = incdt.PriceCPlus,
                                  SumPriceCPlus = incdt.SumPriceCPlus,
                                  Tax = incdt.Tax,
                                  TaxSum = incdt.TaxSum,
                                  TotalPrice = incdt.TotalPrice,
                                  TotalPriceCur = incdt.TotalPriceCur,
                                  Sert = incdt.Sert,
                                  Prod = incdt.Prod,
                                  Bar = bF.BarcF
                              }).ToArray();
Ошибка на сркине
Миниатюры
Как выполнить данный запрос SQL В Linq  
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
02.05.2022, 15:28
Ответы с готовыми решениями:

Как выполнить простой SELECT запрос с помощью Linq to SQL?
class Program { static SqlConnection conn; static void Main(string args) { try ...

Как выполнить данный запрос
Как выполнить данный запрос. Получить номера проектов, обеспечиваемых по крайней мере всеми деталями поставщика П1 Поставщики S ...

Как выполнить данный запрос
Как выполнить данный запрос. Получить номера проектов, обеспечиваемых по крайней мере всеми деталями поставщика П1 Поставщики S ...

2
4 / 4 / 1
Регистрация: 15.04.2017
Сообщений: 346
02.05.2022, 15:35  [ТС]
Результаты запроса на ms sql
Миниатюры
Как выполнить данный запрос SQL В Linq  
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
03.05.2022, 10:05
BOEHKOMAT, для left join нужно писать иначе
https://docs.microsoft.com/en-... uter-joins
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
03.05.2022, 10:05
Помогаю со студенческими работами здесь

Как запрос sql превратить в LINQ?
Как можно превратить вот такой запрос в LINQ ? const string sql = "SELECT * FROM books " + "WHERE NOT...

Как запрос из sql повторить в linq?
Добрый день У меня есть такой запрос string query1 = "SELECT c.ProductType as , AVG(c.Quantity) as " + ...

Как будет выглядеть SQL запрос в LINQ?
SELECT .OrdCount, .OrdInDate, Zak.ZakName FROM Zak INNER JOIN ON Zak.ZakCount = .ZakCount ORDER BY...

Как написать этот запрос SQL, но на LINQ?
Всем привет, сломал голову. Как это написать на линк? Есть ли какие-то нормальныe конвертеры для этого... SELECT TOP 3...

Как сделать данный SQL запрос?
Запрос: На какую сумму проданно билетов, в каждом кинотеатре, в каждый день показа. Данный запрос я уже начала делать, называется в...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru