Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2011.11.20;
Скачать: CL | DM;

Вниз

Помогите написать SQL запрос...   Найти похожие ветки 

 
ixen   (2011-07-28 14:29) [0]

СУБД Firebird... вобщем суть в следующем.. есть таблица clients справочник клиентов, и moves их заказы

clients
Id - первичный ключ
client_name - имя клиента
summ - сумма заказов

moves
Id - первичный ключ
client_id - id клиента
kolvo - количество
price - цена единицы

нужно записать в поле sum таблицы clients стоимость всех их заказов...
можно ли сделать это одним запросом?
пока остановился на следующем... дальше не могу сообразить...

update clients set summ=(select cast(sum(m.kolvo*m.price)as numeric(15,2)) from clients c join moves m on c.id=m.client_id where m.type_doc in ("U","M"))

в результате происходит запись всем клиентам одну и туже сумму...


 
Омлет ©   (2011-07-28 14:41) [1]

UPDATE clients c
SET summ = (
 SELECT CAST(SUM(kolvo * price) AS NUMERIC(15,2))
 FROM moves m
 WHERE (c.id = m.client_id) AND (m.type_doc in ("U", "M"))
);


 
ixen   (2011-07-28 14:53) [2]

все работает.. спасибо большое...


 
Dennis I. Komarov ©   (2011-07-28 15:26) [3]

цена - "price", а вот количество "kolvo"



Страницы: 1 вся ветка

Текущий архив: 2011.11.20;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.007 c
15-1311830801
George
2011-07-28 09:26
2011.11.20
Сравнение текстов


15-1311338373
icelex
2011-07-22 16:39
2011.11.20
ээээх, пятниццо


2-1311843120
Александр160591
2011-07-28 12:52
2011.11.20
запарка с компонентами и их свойствами


2-1311757172
SQLEXPRESS
2011-07-27 12:59
2011.11.20
Работать с Word, не через буфер обмена


15-1311077706
>|<
2011-07-19 16:15
2011.11.20
Как назвать ТЗ?