Как бы мне правильно сделать запрос?

From
Alex Bakhtin (2:5020/400)
To
All
Date
2005-11-30T18:12Z
Area
SU.DBMS.SQL
From: Alex Bakhtin <bakhtin@amt.ru>

Привет.

        Чтобы не было вопросов, сразу скажу - базами данных не занимаюсь,
когда-то давно прослушал курс, но все забыл. Переодически приходится делать
специфические выборки из базы данных, которые не предусмотрены при ее
разработке, каждый раз это начинается со скачивания доки;)

        Итак, что мы имеем. Есть таблица в которой хранится информация об
trouble tickets. У каждого обращения есть параметры:
1. ID - делается из даты + порядкового номера за эту дату
2. Дата и время открытия (поле DATE)
3. Дата и время закрытия (результат вызова процедуры getcloseddate(id),
   если еще не закрыт - то NULL).

        Что мне надо - получить табличку за определенный интервал (грубо
говоря - за год), вида

Дата --- Кол-во TT, находящихся в открытом состоянии на эту дату(то есть
         именьших более раннюю дату открытия и более позднюю дату открытия)

        Все это живет на оракле под солярой. Производительность - не
интересует, select будет выполняться редко. Осложняется все тем, что крайне
желательно сделать это через один селект.

        Я породил вот такой код:

select TO_CHAR(d), count(id) from 
  (select * from 
    (select id, startdate 
     from cases 
     where contract like :3) c, 
  (select DISTINCT D from 
    (select to_date(substr(id,1,4) ||
            '/' || substr(id,5,2) || 
            '/' || substr(id,7,2),
            'YYYY/MM/DD') as d,
    startdate from cases 
    where startdate>=:1 and 
          startdate<=:2)
  )d 
  where c.startdate<=d.d and  
    (getcloseddate(c.id)>=d.d or
     getcloseddate(c.id) is NULL)
  )
group by d

      Безумная конструкция 

  (select DISTINCT D from 
    (select to_date(substr(id,1,4) ||
            '/' || substr(id,5,2) || 
            '/' || substr(id,7,2),
            'YYYY/MM/DD') as d,
    startdate from cases 
    where startdate>=:1 and 
          startdate<=:2)
  )d 

     результат того, что я не придумал, как мне просто перебрать все даты
за определенный период (:1, :2 и :3 - подставляются вводимые пользователем
параметры), в результате генерируется курсор из всех дней, в которые
открывался хотя-бы один кейс. Но, в результате того, что существуют дни, за
которые записей нет вообще - табличка получается неполной, в результате
обрабатывать это сложнее (в частности строить графики). Что можно сделать,
чтобы происходил перебор всех дат за указанный период?

-- 
Best regards, Alex Bakhtin, CCIE #8439
AMT Group, Cisco Systems Gold Partner, http://www.amt.ru
--- ifmail v.2.15dev5.3
 * Origin: AMT Group (2:5020/400)
SEEN-BY: 46/50 50/12 203 520 450/159 186 1024 451/30 454/9 461/43 132 640
SEEN-BY: 469/999 4614/20 4616/3 4625/8 4627/10 4641/444 5000/76 5000 5001/5001
SEEN-BY: 5006/1 5007/1 5010/53 70 5011/13 5012/23 46 5015/10 28 5019/31
SEEN-BY: 5020/86 118 175 194 400 545 604 639 715 758 830 892 982 1042 1057
SEEN-BY: 5020/1200 1523 1604 1665 1909 1922 2013 2020 2238 4441 5021/3 29
SEEN-BY: 5022/128 5025/3 750 5026/10 14 45 5027/16 5029/32 5030/115 217 436
SEEN-BY: 5030/473 556 966 1063 1339 1900 5035/38 5036/1 34 5040/47 5042/13
SEEN-BY: 5045/7 5047/43 47 5049/1 5051/15 5053/16 5054/1 8 9 28 35 37 45 63 67
SEEN-BY: 5055/95 5057/1 5059/9 5060/88 5061/15 5062/1 5066/18 5069/7 5070/1222
SEEN-BY: 5077/70 5080/68 1003 5081/2 5082/6 5083/21 5084/32 5085/13 5090/106
SEEN-BY: 5093/27 5095/20 5099/133 6000/12 254 6009/1
PATH: 5020/400 4441 545 5054/1 37