Модераторы: skyboy
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [Oracle]Запрос с датами 
:(
    Опции темы
Gangleon
Дата 25.12.2008, 21:15 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 12
Регистрация: 23.3.2008

Репутация: нет
Всего: нет



Есть простенькая табличка Event_date, в которой 3 поля:
id
Event_id - событие
date - дата события

Нужно вывести список дат от минимального в таблице, до максимального с указанием сколько событий произошло в этот день. 
Все было бы совсем просто, но даты на которые нет событий тоже надо выводить. 

Тоесть если табличка такая:
Id     Event_id     date
1         11          24.01.08
2         11          24.01.08
3         11          26.01.08
4         11          28.01.08
5         11          02.02.08

То вывестист должно:
24.01.08      2
25.01.08      0
26.01.08      1
27.01.08      0
28.01.08      1
29.01.08      0
30.01.08      0
01.02.08      0
02.02.08      1

Как это возможно сделать? 

PM MAIL   Вверх
Akina
Дата 25.12.2008, 22:05 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20581
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 45
Всего: 454



Цитата(Gangleon @  25.12.2008,  22:15 Найти цитируемый пост)
Как это возможно сделать?

Для такого требуется таблица дат. Или её придётся генерить процедурно (скажем, в хранимке). Возможно, в каких-то диалектах есть для этого спецсредства - но я таких не помню.


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
Gangleon
Дата 25.12.2008, 22:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 12
Регистрация: 23.3.2008

Репутация: нет
Всего: нет



В данном случае надо реализовать в Oracle
PM MAIL   Вверх
Gangleon
Дата 25.12.2008, 22:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 12
Регистрация: 23.3.2008

Репутация: нет
Всего: нет



Хорошо, как тогда сгенерить эту таблицу процедурно? Как в запросе создать таблиуцу от одной даты до другой включающую все промежуточные даты?
PM MAIL   Вверх
Zloxa
Дата 26.12.2008, 10:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3473
Регистрация: 12.9.2008

Репутация: 53
Всего: 161



Код

SQL> with t as (
  2    select 1 id,        11 Event_id          ,to_Date('24.01.08','DD.MM.YYYY') dt from dual
  3    union all select 2         ,11          ,to_Date('24.01.08','DD.MM.YYYY') from dual
  4    union all select 3         ,11          ,to_Date('26.01.08','DD.MM.YYYY') from dual
  5    union all select 4         ,11          ,to_Date('28.01.08','DD.MM.YYYY') from dual
  6    union all select 5         ,11          ,to_Date('02.02.08','DD.MM.YYYY') from dual
  7  )
  8  select s.dt, nvl(t.cnt,0) cnt
  9  from (
 10    select mind+level-1 dt
 11     from (select min(dt) mind,max(dt) maxd from t )
 12    connect by level +mind -1 <= maxd
 13    ) s
 14  left join (select count(*) cnt,dt from t group by dt) t on s.dt = t.dt
 15  order by 1;
 
DT                 CNT
----------- ----------
24.01.0008           2
25.01.0008           0
26.01.0008           1
27.01.0008           0
28.01.0008           1
29.01.0008           0
30.01.0008           0
31.01.0008           0
01.02.0008           0
02.02.0008           1
 
10 rows selected




--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Составление SQL-запросов | Следующая тема »


 




[ Время генерации скрипта: 0.0845 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.