Запись Mysql по дням на интервале времени - PullRequest
0 голосов
/ 15 января 2019

У меня есть таблица событий (сейчас около 2 или 3 миллионов) с датами начала и окончания (разброс на несколько лет). Хочу узнать, сколько событий существует каждый день. Не начинается днем, но происходит каждый календарный день. Э.Г.

| name | start      | End        |
| Ev1  | 2019/01/01 | 2019/01/03 |
| Ev2  | 2019/01/02 | 2019/01/04 |
| Ev3  | 2019/02/22 | 2019/02/23 |

Ожидаемый результат:

| day        | # |
| 2019/01/01 | 1 |
| 2019/01/02 | 2 |
| 2019/01/03 | 2 |
| 2019/01/04 | 1 |
| 2019/01/05 | 0 |
|     ...    | 0 |
| 2019/02/22 | 1 |
| 2019/02/23 | 1 |

Ответы [ 3 ]

0 голосов
/ 15 января 2019

Было бы целесообразно иметь таблицу календаря для такого рода информации. Тогда,

select c_date, count(*)
from calendar c
inner join events on e.start <= c_date and c_date <= e.end
group by c_Date;
0 голосов
/ 15 января 2019

попробуйте что-то вроде этого, вам нужен генератор даты.

select
    d.dte, count(e.start) as cnt
from 
(
select dte from
    (select adddate('1970-01-01',t4*10000 + t3*1000 + t2*100 + t1*10 + t0) dte from
    (select 0 t0 union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t0,
    (select 0 t1 union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t1,
    (select 0 t2 union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t2,
    (select 0 t3 union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t3,
    (select 0 t4 union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t4) v
Where dte between '2019-01-01' and '2020-12-31'
) d
inner join events e
     on e.start <= d.dte and d.dte <= e.end
group by d.dte
0 голосов
/ 15 января 2019

Это сложно. В MySQL начните с дат и используйте коррелированный подзапрос:

select d.dte, count(e.start) as cnt
from (select date('2019-01-01') as dte union all
      select date('2019-01-02') as dte union all
      select date('2019-01-03') as dte union all
      select date('2019-01-04') as dte
     ) d left join
     events e
     on e.start <= d.dte and d.dte <= e.end
group by d.dte
order by d.dte;
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...