Форум: "Базы";
Поиск по всему сайту: 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.024 c
1-66892           Oak                   2002-03-05 20:31  2002.03.21  
Проблема с JPEG


14-66981          Mike_Goblin           2002-01-27 18:09  2002.03.21  
Кто смотрел кино


14-66979          vopros                2002-02-07 16:39  2002.03.21  
Кто от куда прпроизошел.


3-66792           Bura                  2002-02-22 22:09  2002.03.21  
Дурацкий вопрос...


3-66750           Sys                   2002-02-20 21:42  2002.03.21  
Помогите сделать первые шаги в Intrbase