Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/5: Рейтинг темы: голосов - 5, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 16.12.2010
Сообщений: 31
MS Access

Вычисление остатка и расхода в запросе по каждому товару

04.06.2014, 14:33. Показов 950. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте! Создаю БД на Делфи, СУБД - MS Access. Делаю объединенный запрос, который должен выводить расход и остаток по каждому товару на заданный период. Получилось только вычислить остаток (см. рисунок), а нужно, чтобы выводился еще и расход по каждому товару.
Вот сам запрос:
SQL
1
2
3
4
5
6
7
8
9
SELECT Товар.Наименование_товара, Вид_товара.Сорт_товара, Единица_измерения.Название_единицы_измерения, SUM(kolvo)
FROM (SELECT DISTINCTROW  Товар.Наименование_товара, Вид_товара.Сорт_товара, Единица_измерения.Название_единицы_измерения, SUM(Состав.Объем_поступившего_товара) AS kolvo
FROM (Единица_измерения INNER JOIN (Вид_товара INNER JOIN Товар ON Вид_товара.[Код_вида_товара] = Товар.[Код_вида_товара]) ON Единица_измерения.[ID_единицы_измерения] = Товар.[ID_единицы_измерения]) INNER JOIN (Приход INNER JOIN Состав ON Приход.[ID_прихода] = Состав.[ID_прихода]) ON Товар.[Код_товара] = Состав.[Код_товара]
WHERE Приход.Дата_поступления BETWEEN :dat1 AND :dat2 GROUP BY Товар.Наименование_товара, Вид_товара.Сорт_товара, Единица_измерения.Название_единицы_измерения
UNION
(SELECT DISTINCTROW  Товар.Наименование_товара, Вид_товара.Сорт_товара, Единица_измерения.Название_единицы_измерения, -SUM(Состав_по_материальным_требованиям.Объем_отпущенного_товара) AS kolvo
FROM Материальные_требования INNER JOIN ((Единица_измерения INNER JOIN (Вид_товара INNER JOIN Товар ON Вид_товара.[Код_вида_товара] = Товар.[Код_вида_товара]) ON Единица_измерения.[ID_единицы_измерения] = Товар.[ID_единицы_измерения]) INNER JOIN Состав_по_материальным_требованиям ON Товар.[Код_товара] = Состав_по_материальным_требованиям.[Код_товара]) ON Материальные_требования.[Номер_материального_требования] = Состав_по_материальным_требованиям.[Номер_материального_требования]
WHERE Материальные_требования.Дата BETWEEN :dat1 AND :dat2 GROUP BY  Товар.Наименование_товара, Вид_товара.Сорт_товара, Единица_измерения.Название_единицы_измерения)) 
GROUP BY Товар.Наименование_товара, Вид_товара.Сорт_товара, Единица_измерения.Название_единицы_измерения;
Подскажите, пожалуйста, как исправить. База данных вложена
Миниатюры
Вычисление остатка и расхода в запросе по каждому товару  
Вложения
Тип файла: rar База данных.rar (92.9 Кб, 21 просмотров)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
04.06.2014, 14:33
Ответы с готовыми решениями:

Как вставить тег <vendor_name type="str"></vendor_name>, каждому товару?
Добрый день! У меня более 10000 товаров и с меня требуют добавить каждому товару &lt;vendor_name...

Отображать в запросе более позднюю дату по каждому клиенту
Привет) В таблице, по которой делаю запрос, есть поля &quot;Клиент&quot; и &quot;Дата замеров&quot;. Какое условие нужно поставить в поле &quot;Дата...

Как в запросе вытащить максимальные значения времени по каждому пользователю?
Добрый день, есть 2 таблицы - заказы и клиенты, мне нужно вытащить клиентов , которые 30 дней ничего не покупали. Можно конечно...

1
0 / 0 / 0
Регистрация: 16.12.2010
Сообщений: 31
04.06.2014, 14:50  [ТС]
Вопрос уже неактуален, вот исправленный запрос:
SQL
1
2
3
4
5
6
7
8
9
SELECT Товар.Наименование_товара, Вид_товара.Сорт_товара, Единица_измерения.Название_единицы_измерения, SUM(kolvo), SUM(ras), SUM(prih)
FROM (SELECT DISTINCTROW  Товар.Наименование_товара, Вид_товара.Сорт_товара, Единица_измерения.Название_единицы_измерения, SUM(Состав.Объем_поступившего_товара) AS kolvo, 0 AS ras, SUM(Состав.Объем_поступившего_товара) AS prih
FROM (Единица_измерения INNER JOIN (Вид_товара INNER JOIN Товар ON Вид_товара.[Код_вида_товара] = Товар.[Код_вида_товара]) ON Единица_измерения.[ID_единицы_измерения] = Товар.[ID_единицы_измерения]) INNER JOIN (Приход INNER JOIN Состав ON Приход.[ID_прихода] = Состав.[ID_прихода]) ON Товар.[Код_товара] = Состав.[Код_товара]
WHERE Приход.Дата_поступления BETWEEN :dat1 AND :dat2 GROUP BY Товар.Наименование_товара, Вид_товара.Сорт_товара, Единица_измерения.Название_единицы_измерения
UNION
(SELECT DISTINCTROW  Товар.Наименование_товара, Вид_товара.Сорт_товара, Единица_измерения.Название_единицы_измерения, -SUM(Состав_по_материальным_требованиям.Объем_отпущенного_товара) AS kolvo, SUM(Состав_по_материальным_требованиям.Объем_отпущенного_товара) AS ras, 0 AS prih
FROM Материальные_требования INNER JOIN ((Единица_измерения INNER JOIN (Вид_товара INNER JOIN Товар ON Вид_товара.[Код_вида_товара] = Товар.[Код_вида_товара]) ON Единица_измерения.[ID_единицы_измерения] = Товар.[ID_единицы_измерения]) INNER JOIN Состав_по_материальным_требованиям ON Товар.[Код_товара] = Состав_по_материальным_требованиям.[Код_товара]) ON Материальные_требования.[Номер_материального_требования] = Состав_по_материальным_требованиям.[Номер_материального_требования]
WHERE Материальные_требования.Дата BETWEEN :dat1 AND :dat2 GROUP BY  Товар.Наименование_товара, Вид_товара.Сорт_товара, Единица_измерения.Название_единицы_измерения))  
GROUP BY Товар.Наименование_товара, Вид_товара.Сорт_товара, Единица_измерения.Название_единицы_измерения;
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
04.06.2014, 14:50
Помогаю со студенческими работами здесь

Вычисление остатка
Здравствуйте! Есть очень большое произведение(100*101*102*...*100000) Нужно вычислить остаток этого произведения при делении на 23, как...

Вычисление остатка
Дорогие форумчане, не подскажите, есть ли такая функция Function(a, b) = c Которая бы, при целочисленном делении a на b, выводила бы...

Вычисление остатка от деления
Реализую один криптографический стандарт. И столкнулся с такой задачей: \bar{u} = 64 mod {2}^{64} Если верить калькуляторам то ответ...

Вычисление остатка от числа
Здравствуйте, дорогие форумчане. При использовании функции &quot;%&quot; в примере ниже получается значение равное 0.34000000000000341. Прошу...

Вычисление остатка времени
Приветствую всех! Понимаю, вопрос детский, но подскажите, плиз, синтаксис: Имеем: Фиксированное время по продолжительности (время...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 11.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 10.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru