Модераторы: Akina
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> SQL запрос на получение суммы заказа 
V
    Опции темы
zhuchok
Дата 25.1.2011, 17:14 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 28
Регистрация: 14.11.2006
Где: Владивосток

Репутация: нет
Всего: 1



Помогите пожалуйста! Не могу написать запрос для получения суммы по заказу.
Необходимо получить сумму по заказанным товарам, сумму по всем состояниям истории и сумму этих двух выражений, умноженную на скидку.

Вот таким образом все работает:
Код

SELECT order_client.id_order, 
Sum(order_goods.amount*goods.cost) AS Sum_goods, 
Sum(order_history.hours*stage_order.cost_in_hour) AS Sum_History, 
Sum(order_client.disk) AS [Sum-disk], 
Sum((1-order_client.disk)*((order_goods.amount*goods.cost+order_history.hours*stage_order.cost_in_hour))) AS Sum_order
FROM goods INNER JOIN (stage_order INNER JOIN (order_history INNER JOIN (order_client INNER JOIN order_goods 
ON order_client.id_order=order_goods.id_order) 
ON order_client.id_order=order_history.id_order) 
ON stage_order.id_stage=order_history.id_stage) 
ON goods.id_goods=order_goods.id_goods
GROUP BY order_client.id_order;


Но проблемма в том, что не по каждому заказу есть история. А суммы нужны по всем! 

Пробовала так:
Код

SELECT order_client.id_order, 
Sum(order_goods.amount*goods.cost) AS Sum_goods, 
Sum(order_history.hours*stage_order.cost_in_hour) AS Sum_History, 
Sum(order_client.disk) AS [Sum-disk], 
Sum((1-order_client.disk)*((order_goods.amount*goods.cost+order_history.hours*stage_order.cost_in_hour))) AS Sum_order
FROM goods INNER JOIN (stage_order INNER JOIN (order_history RIGHT JOIN (order_client LEFT JOIN order_goods 
ON order_client.id_order=order_goods.id_order) 
ON order_client.id_order=order_history.id_order) 
ON stage_order.id_stage=order_history.id_stage) 
ON goods.id_goods=order_goods.id_goods
GROUP BY order_client.id_order;

Тогда вообще ошибка "не потдерживается выражение объединения".

Это сообщение отредактировал(а) zhuchok - 25.1.2011, 19:00

Присоединённый файл ( Кол-во скачиваний: 1 )
Присоединённый файл  reclama.zip 13,50 Kb
PM MAIL ICQ   Вверх
Akina
Дата 25.1.2011, 17:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20570
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 30
Всего: 453



Цитата(zhuchok @  25.1.2011,  18:14 Найти цитируемый пост)
Если кто подскажет как залить картинку могу разместить структуру таблицы

Модератор: Если кто-то не прочитает закреплённые темы форума ... 


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
zhuchok
Дата 26.1.2011, 02:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 28
Регистрация: 14.11.2006
Где: Владивосток

Репутация: нет
Всего: 1



Проблема решена следующим образом:
Код

SELECT order_client.id_order, 
Sum(Nz(order_goods.amount*goods.cost)) AS Sum_goods, 
Sum(Nz(order_history.hours*stage_order.cost_in_hour)) AS Sum_History, 
Sum(order_client.disk) AS [Sum-disk], 
Sum((1-order_client.disk)*((Nz(order_goods.amount)*Nz(goods.cost)+Nz(order_history.hours)*Nz(stage_order.cost_in_hour)))) AS Sum_order
FROM stage_order RIGHT JOIN ((order_client LEFT JOIN (goods RIGHT JOIN order_goods 
ON goods.id_goods=order_goods.id_goods) 
ON order_client.id_order=order_goods.id_order) LEFT JOIN order_history 
ON order_client.id_order=order_history.id_order) 
ON stage_order.id_stage=order_history.id_stage
GROUP BY order_client.id_order;

PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "MS Access"
Akina
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • Используйте теги [code=vb][/code] и [code=sql][/code] для подсветки кода. Используйтe чекбокс "транслит" (возле кнопок кодов) если у Вас нет русских шрифтов.

Запрещается!

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Akina.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | MS Access | Следующая тема »


 




[ Время генерации скрипта: 0.1201 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.