Главная страница
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.005 c
15-1311061925
Unknown555
2011-07-19 11:52
2011.11.20
оператор goto


9-1190053787
Mr.Vlad
2007-09-17 22:29
2011.11.20
Targa&Viewer


15-1311539404
Юрий
2011-07-25 00:30
2011.11.20
С днем рождения ! 25 июля 2011 понедельник


1-1273589288
guest
2010-05-11 18:48
2011.11.20
Закорючки в Excel


9-1190291664
sloosar1
2007-09-20 16:34
2011.11.20
Рисование на панели