Форум: "Базы";
Поиск по всему сайту: delphimaster.net;
Текущий архив: 2002.03.21;
Скачать: [xml.tar.bz2];




Вниз

связывание таблиц 


perov   (2002-02-20 10:33) [0]

есть три таблицы (скажем счета, приход, расход). как правильно составить запрос, чтобы выбиралось суммарное движение по ВСЕМ счетам, а не только по тем, информация по которым есть и в приходе и в расходе (если движений не было, то должен выбраться 0)



xcb   (2002-02-20 10:44) [1]

подробнее о структуре если можно...

а вообще примерно так

select a.id_shet, ss.name, a.p_sum , a.r_sum, a.p_sum - a.r_sum ost_sum
from
(select s.id_shet, sum (p.summ) p_sum, sum (r.summ) r_sum
from shet s, prixod p, rasxod r
where s.id_shet = p.id_shet (+)
and s.id_shet = r.id_shet (+)
group by s.id_shet) a, shet ss
where a.id_shet = ss.id_shet



xcb   (2002-02-20 10:48) [2]

да... забыл про нули...
не sum (p.summ) p_sum
a nvl(sum (p.summ), 0) p_sum
и nvl(sum (r.summ), 0) r_sum
...



perov   (2002-02-20 11:08) [3]

accounts (id numeric, name char(10), ........)
payments (accid numeric, odate date, summa numeric (15,2), type char (1), .....)
calculations (accid numeric, docdate date, forpayment numeric (15,2), type char(1), ..... )



perov   (2002-02-20 12:51) [4]

запрос работает,
но если я дабавляю условия, например, по дате, то запрос выдает неверные данные :(((



xcb   (2002-02-20 15:37) [5]

select a.id_shet, ss.name, a.p_sum , a.r_sum, a.p_sum - a.r_sum ost_sum
from
(select s.id_shet,
nvl(sum (p.summ), 0) p_sum,
nvl(sum (r.summ), 0) r_sum
from shet s,
(select id_shet, sum(summ) from (select id_shet, summ
from prixod where docdate between :begdat and :enddat)) p,
(select id_shet, sum(summ) from (select id_shet, summ
from rashod where docdate between :begdat and :enddat)) r
where s.id_shet = p.id_shet (+)
and s.id_shet = r.id_shet (+)
group by s.id_shet) a, shet ss
where a.id_shet = ss.id_shet

где :begdat и :enddat переменные соотв начало и конец периода...




Форум: "Базы";
Поиск по всему сайту: delphimaster.net;
Текущий архив: 2002.03.21;
Скачать: [xml.tar.bz2];




Наверх





Память: 0.72 MB
Время: 0.029 c
7-67021           IIL                   2001-12-19 14:16  2002.03.21  
Разрешение экрана


4-67052           dr0Ne64               2002-01-24 01:07  2002.03.21  
Иконка в Systray


3-66755           dymka                 2002-02-21 08:53  2002.03.21  
Нужен совет по проектированию системы


1-66882           DeNNiss               2002-03-05 14:44  2002.03.21  
Вопрос


14-66958          McSimm                2002-02-06 10:21  2002.03.21  
Об оптимизации.