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

Вниз

Уважаемые Мастера, вопрос по SQL...   Найти похожие ветки 

 
KMM   (2002-02-06 12:22) [0]

Есть три таблицы:
Firm:(фирмы)
id_firm //шифр фирмы
name_firm //название

Prih:(приходные накладные)
id_prih //шифр приходной накладной
id_firm //шифр фирмы
summ_prih //сумма приходной накладной

RAsh: (расходные накладные)
id_rash //шифр расходной накладной
id_firm //шифр фирмы
summ_rash //сумма расходной накладной

Мне необходимо в результате запроса получить список фирм и для каждой из них суммарный приход и суммарный расход

Пишу что-то вроде:
SELECT
firm.id_firm, firm.name_firm,
Sum(prih.summ_prih) AS PRIHOD,
Sum(rash.summ_rash) AS RASHOD
FROM (firm LEFT JOIN prih ON firm.id_firm = prih.id_firm)
LEFT JOIN rash ON firm.id_firm = rash.id_firm
GROUP BY firm.id_firm, firm.name_firm

Однако это неправильно, судя по результатам (суммирование происходит многократное).
Подскажите, пожалуйста как решить эту проблему.


 
skiph ©   (2002-02-12 07:47) [1]

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


 
Леша   (2002-02-12 09:18) [2]

select id_firm, nm_firm,
(select sum(summ_prih) from Prich where Prich.id_firm=Firm.id_firm) as prihod,
(select sum(summ_rach) from Rach where Rach.id_firm=Firm.id_firm) as rashod from firm


 
KMM   (2002-02-13 11:03) [3]

>Леше : Не работает.

Интересно, эта задача вообще решается (в смысле - одним запросом)?


 
KMM   (2002-02-13 11:45) [4]

>Леше. Дико извиняюсь, РАБОТАЕТ!!! (я сначала ошибся при проверке). Премного благодарен!

>skiph. Я тоже делал это через вспомогательную таблицу, а оказывается это можно решить проще. Ура!




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

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

Наверх




Память: 0.47 MB
Время: 0.01 c
1-32493
Дмитрий Катаев
2002-02-25 00:21
2002.03.11
Опитмизация в Deplhi


3-32392
Nest
2002-02-12 11:26
2002.03.11
Надо сформировать запрос (Select). Мыслб крутится, но не могу ухвтить - помогите пожалуйста. Очень пожалуйста.


1-32450
yaJohn
2002-02-20 13:11
2002.03.11
bistraya Windows ;)))


7-32596
VEG
2001-11-19 16:41
2002.03.11
Крупный шрифт


6-32534
Yuri Btr
2001-12-24 17:08
2002.03.11
Net send