Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
0 / 0 / 0
Регистрация: 08.01.2017
Сообщений: 16

Сложный мега запрос

20.01.2017, 15:15. Показов 881. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите пожалуйста, мне нужно стделать так как написано в третем задании и нужно чтоб дата и склад задавались как в 1 и 2 примере.
1. По документам "Договор" поличить общее количество каждого запланированного к отгрузке изделия по заданному скаду в заданном месяце.
SQL
1
2
3
4
5
6
7
SELECT        dbo.table_dogovor.id_izdeliya, dbo.dogovor.id_dogovora, dbo.izdeliya.nazvanie_izdeliya, SUM(dbo.table_dogovor.colichestvo_izdeliya) AS sumDogColIzd, 
                         SUM(dbo.izdeliya.price * dbo.table_dogovor.colichestvo_izdeliya) AS sumPrice
FROM            dbo.dogovor INNER JOIN
                         dbo.table_dogovor ON dbo.dogovor.id_dogovora = dbo.table_dogovor.id_dogovora INNER JOIN
                         dbo.izdeliya ON dbo.table_dogovor.id_izdeliya = dbo.izdeliya.id_izdeliya
WHERE        (dbo.izdeliya.id_sklada = 1) AND (MONTH(dbo.table_dogovor.Data_Otgruzki) = 1)
GROUP BY dbo.table_dogovor.id_izdeliya, dbo.dogovor.id_dogovora, dbo.izdeliya.nazvanie_izdeliya
2.По документам "Цеховая накладная" получить общее количество каждого выпущенного изделия по заданному складу в заданном месяце.
SQL
1
2
3
4
5
6
7
SELECT        dbo.izdeliya.id_izdeliya, dbo.table_ceh_nakl.id_nakl, dbo.izdeliya.nazvanie_izdeliya, dbo.cehovaya_nakladnaya.id_ceh_nakl, 
                         SUM(dbo.table_ceh_nakl.colichestvo_izdeliya) AS SumCNIzd, SUM(dbo.izdeliya.price * dbo.table_ceh_nakl.colichestvo_izdeliya) AS sumPrice
FROM            dbo.cehovaya_nakladnaya INNER JOIN
                         dbo.table_ceh_nakl ON dbo.cehovaya_nakladnaya.id_ceh_nakl = dbo.table_ceh_nakl.id_nakl INNER JOIN
                         dbo.izdeliya ON dbo.table_ceh_nakl.id_izdeliya = dbo.izdeliya.id_izdeliya
WHERE        (MONTH(dbo.cehovaya_nakladnaya.data_nakl) = 12) AND (dbo.izdeliya.id_sklada = 1)
GROUP BY dbo.table_ceh_nakl.id_nakl, dbo.cehovaya_nakladnaya.id_ceh_nakl, dbo.izdeliya.id_izdeliya, dbo.izdeliya.nazvanie_izdeliya
3.ПОДЧСИТАТЬ ОТКЛОНЕНИЕ КАК РАЗНОСТЬ МЕЖДУ ПЕРВОЙ И ВТОРОЙ СУММАМИ В СТОЙМОСТНОМ ВЫРАЖЕНИЕИ
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
20.01.2017, 15:15
Ответы с готовыми решениями:

Сложный запрос к БД
Есть БД, в ней таблица main с полями ip(адрес абонента),datetime(время запроса),size(размер ответа в байтах). Внимание!!!! Необходимо...

Сложный запрос
Здравствуйте!у меня есть БД: Успеваемость(#Nз, #ИдКурса, #Семестр, #УчНед, #ВидОтчета, Оценка) ОтчетГруппы(#ИдКурса, #Nгр, #УчНед,...

Сложный запрос
Всем привет! (пример) Есть 3 таблицы:Users, Auto, Motorcycles. (Они связаны через ключевое поле userID.) Мне нужно вывести...

5
1040 / 856 / 335
Регистрация: 08.12.2016
Сообщений: 3,283
20.01.2017, 17:06
первую сумму по каждому договору считала, а вторую - по каждой накладной. Как теперь вычитать то собираешься?
Тем более, что в первом и втором задании этого и не требовалось, нужна была группировка только по изделиям.

10 дней назад уже в трех вариантах ЭТОТ САМЫЙ запрос писали, не надоело одно и то же регулярно переспрашивать? Мне отвечать, извини, уже надоело
1
0 / 0 / 0
Регистрация: 08.01.2017
Сообщений: 16
20.01.2017, 18:50  [ТС]
Можешь помочь добавить в этот запрос дату и склад как в первом запросе строка №6
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
SELECT        dbo.izdeliya.nazvanie_izdeliya, ISNULL(poDogovoru.sumPoDogovoru, 0) AS sumPoDogovoru, ISNULL(poCeh.sumPoCeh, 0) AS sumPoCeh, 
                         ISNULL(poCeh.sumPoCeh, 0) - ISNULL(poDogovoru.sumPoDogovoru, 0) AS Raznica
FROM            (SELECT        izdeliya_2.id_izdeliya, SUM(dbo.table_dogovor.colichestvo_izdeliya * izdeliya_2.price) AS sumPoDogovoru
                          FROM            dbo.table_dogovor INNER JOIN
                                                    dbo.izdeliya AS izdeliya_2 ON dbo.table_dogovor.id_izdeliya = izdeliya_2.id_izdeliya
                          GROUP BY izdeliya_2.id_izdeliya) AS poDogovoru LEFT OUTER JOIN
                             (SELECT        izdeliya_1.id_izdeliya, SUM(dbo.table_ceh_nakl.colichestvo_izdeliya * izdeliya_1.price) AS sumPoCeh
                               FROM            dbo.table_ceh_nakl INNER JOIN
                                                         dbo.izdeliya AS izdeliya_1 ON dbo.table_ceh_nakl.id_izdeliya = izdeliya_1.id_izdeliya
                               GROUP BY izdeliya_1.id_izdeliya) AS poCeh ON poDogovoru.id_izdeliya = poCeh.id_izdeliya INNER JOIN
                         dbo.izdeliya ON dbo.izdeliya.id_izdeliya = ISNULL(poDogovoru.id_izdeliya, poCeh.id_izdeliya)
GROUP BY dbo.izdeliya.nazvanie_izdeliya, ISNULL(poDogovoru.sumPoDogovoru, 0), ISNULL(poCeh.sumPoCeh, 0), ISNULL(poCeh.sumPoCeh, 0) 
                         - ISNULL(poDogovoru.sumPoDogovoru, 0)
0
1040 / 856 / 335
Регистрация: 08.12.2016
Сообщений: 3,283
21.01.2017, 02:27
копируешь WHERE ... и вставляешь перед GROUP BY в подзапросах
и так 2 раза
0
0 / 0 / 0
Регистрация: 08.01.2017
Сообщений: 16
21.01.2017, 08:08  [ТС]
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
SELECT        dbo.izdeliya.nazvanie_izdeliya, ISNULL(poDogovoru.sumPoDogovoru, 0) AS sumPoDogovoru, ISNULL(poCeh.sumPoCeh, 0) AS sumPoCeh, 
                         ISNULL(poCeh.sumPoCeh, 0) - ISNULL(poDogovoru.sumPoDogovoru, 0) AS Raznica
FROM            (SELECT        izdeliya_2.id_izdeliya, SUM(dbo.table_dogovor.colichestvo_izdeliya * izdeliya_2.price) AS sumPoDogovoru
                          FROM            dbo.table_dogovor INNER JOIN
                                                    dbo.izdeliya AS izdeliya_2 ON dbo.table_dogovor.id_izdeliya = izdeliya_2.id_izdeliya
                          WHERE        (izdeliya_2.id_sklada = 1) AND (MONTH(dbo.table_dogovor.Data_Otgruzki) = 1)
                          GROUP BY izdeliya_2.id_izdeliya) AS poDogovoru LEFT OUTER JOIN
                             (SELECT        izdeliya_1.id_izdeliya, SUM(dbo.table_ceh_nakl.colichestvo_izdeliya * izdeliya_1.price) AS sumPoCeh
                               FROM            dbo.table_ceh_nakl INNER JOIN
                                                         dbo.izdeliya AS izdeliya_1 ON dbo.table_ceh_nakl.id_izdeliya = izdeliya_1.id_izdeliya
                               WHERE        (dbo.izdeliya.id_sklada = 1) AND (MONTH(dbo.cehovaya_nakladnaya.data_nakl) = 12)
                               GROUP BY izdeliya_1.id_izdeliya) AS poCeh ON poDogovoru.id_izdeliya = poCeh.id_izdeliya INNER JOIN
                         dbo.izdeliya ON dbo.izdeliya.id_izdeliya = ISNULL(poDogovoru.id_izdeliya, poCeh.id_izdeliya)
GROUP BY dbo.izdeliya.nazvanie_izdeliya, ISNULL(poDogovoru.sumPoDogovoru, 0), ISNULL(poCeh.sumPoCeh, 0), ISNULL(poCeh.sumPoCeh, 0) 
                         - ISNULL(poDogovoru.sumPoDogovoru, 0)
Миниатюры
Сложный мега запрос  
0
1040 / 856 / 335
Регистрация: 08.12.2016
Сообщений: 3,283
21.01.2017, 10:40
ты уж сама разберись, как у тебя таблица называется
table_ceh_nakl
или
cehovaya_nakladnaya
да и к мега запросу неплохо было бы и мега-схему прикладывать
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
21.01.2017, 10:40
Помогаю со студенческими работами здесь

Сложный запрос
Сгруппировать по keyGroup. Если в группе больше одной записи Если в группе есть хоть одна запись у которой isFirst = 1, получить...

Сложный запрос
Всем доброго времени суток. Всех милых дам с 8 марта!:rose: И так у меня БД: Реляционная модель: Нужно получить...

Сложный запрос
Доброго времени суток! Знатоки SQL подскажите пожалуйста как привести в рабочий вид мой запрос: DECLARE @data AS XML, ...

сложный запрос
Есть таблица А: id | date | number, id - int date - datetime number - int, 0, 1 или 2 Необходим запрос в табл А, где...

Сложный запрос
Не получается реализовать запрос. По идеи я обращаюсь к таблице с консолид.лицами, которые являются физ.лицами и юр.лицами. Есть разные...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru