Главная страница
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.008 c
2-1311793235
Drowsy
2011-07-27 23:00
2011.11.20
При уничтожении модуля данных возникает AV.


15-1310970242
Дмитрий С
2011-07-18 10:24
2011.11.20
Кто нибудь тут может подключить...


8-1204086962
DoKi
2008-02-27 07:36
2011.11.20
opengl2 треугольники


15-1311884998
Юрий
2011-07-29 00:29
2011.11.20
С днем рождения ! 29 июля 2011 пятница


3-1266393561
tomkat
2010-02-17 10:59
2011.11.20
Медленная вставка через TIBScript