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

Вниз

Проблема с count(*) в joined запросе   Найти похожие ветки 

 
EternalWonderer   (2001-12-24 17:20) [0]

Уважаемые Мастера - занатоки SQL! Имеется на первый взгляд несложная задача:

Дано: таблицы CATALOG(ID,CAPTION) и LIST(ID_CAT,OTHER_FIELDS).
LIST.ID_CAT ссылается на CATALOG.ID.
Задача: составить запрос, который выведет ВСЕ строки CATALOG,
в каждой из которых (в столбце COUNTS) будет количество соответствующих им строк из LIST. Если в LIST нет соответствующих строк, должен быть выведен 0 или null.
Варианты решения:
1.select c.ID,c.CAPTION,count(*) COUNTS
from CATALOG c, LIST l
where c.id=l.TYPE_SI(+)
group by c.ID,c.CAPTION;
не потянет, поскольку в строках, которым не соответствует ни одна строка LIST (по условию задачи должен быть 0 или null), прописывается (и совершенно правильно) "1";
2.select c.ID,c.CAPTION,count(*) COUNTS
from CATALOG c, LIST l
where c.id=l.TYPE_SI
group by c.ID,c.CAPTION;
тоже не потянет, поскольку строки CATALOG, ссылок на которые нет в LIST, не будут выведены;

Как быть? Заранее спасибо.


 
Kapusto ©   (2001-12-24 17:43) [1]

А почему бы не использовать LEFT JOIN?


 
Mick   (2001-12-24 17:48) [2]


Select c.ID, c.CAPTION,count(ID_CAT) COUNTS
from CATALOG C, LIST L
where C.Id = L.TYPE_SI(+)
group by c.ID,c.CAPTION


 
Mick   (2001-12-24 17:50) [3]

Всего лишь тонкие отличия команд Count(*) и Count(FieldName)


 
Yuvich ©   (2001-12-24 18:13) [4]

> EternalWonderer
Мне непонятно одно: при чем здесь l.type_si? ведь для list внешний ключ - l.id_cat - потому и не тянет вариант 1.


 
VVP ©   (2001-12-24 19:45) [5]

select C.ID, C.CAPTION, (select count(*) from LIST where ID_CAT=C.ID)
from CATALOG C


 
Mick   (2001-12-25 08:46) [6]

>Yovich
"Type_SI" взялся из самого вопроса, я его скопировал.

Правильно будет конечно же так:
Select C.ID, C.CAPTION,Count(ID_CAT) COUNTS
from CATALOG C, LIST L
where C.ID = L.ID_CAT(+)
group by C.ID,C.CAPTION



 
Vadim ©   (2001-12-25 08:58) [7]

А чтобы выводился не 0 а null, можно сделать так:

Select C.ID, C.CAPTION, COUNTS
from CATALOG C, (select ID_CAT,count(*) COUNTS
from LIST group by ID_CAT)
where C.ID = ID_CAT(+)


 
Mick   (2001-12-25 09:05) [8]

>Vadim

Тогда уж так, памятуя, что это все же Oracle
Select C.ID, C.CAPTION,Decode(Count(ID_CAT),0,NULL,Count(ID_CAT)) COUNTS
from CATALOG C, LIST L
where C.ID = L.ID_CAT(+)
group by C.ID,C.CAPTION




 
EternalWonderer   (2001-12-25 09:32) [9]

Огромное спасибо, особенно Mick"у.



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

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

Наверх




Память: 0.48 MB
Время: 0.015 c
14-90361
Oleg Gashev
2001-12-03 22:06
2002.01.28
БИБЛИЯ ПРОГРАММИСТА


1-90270
dimonf
2002-01-09 21:24
2002.01.28
Народ, как маштабировать одну ось в графике, например Y?


1-90326
Satrap
2002-01-06 11:56
2002.01.28
особенности WndProc


1-90319
Tor
2002-01-08 22:42
2002.01.28
Массивы объектов


1-90263
Tosov
2002-01-08 23:22
2002.01.28
Закраска ячейки StringGrid