|
Sql даты 2
|
|||
---|---|---|---|
#18+
date status name11.08.2020 работает 121.08.2020 не работает 122.08.2020 в процессе 111.09.2020 не работает 212.09.2020 не работает 226.09.2020 работает 201.10.2020 работает 213.09.2021 не работает 314.09.2021 работает 314.09.2021 работает 314.09.2021 не работает 301.10.2021 в процессе 316.10.2021 работает 117.10.2021 не работает 2 Спасибо за прошлое решение авторwith cte as ( select date, name, case when status <> lead(status) over (partition by year(date), month(date), name order by date) then 1 else 0 end change from A ) select year(date), month(date), name, sum(change) + 1 from cte group by year(date), month(date), name having sum(change) >= 3 - 1; авторМне нужно выявить как в промежутке месяца менялся статус. Т.е. работает, не работает, работает. Или работает, не работает в процессе. Т.е предположим значений больше, делаю дистинкт. Потом создаю месячные промежутки и ищу там >= 3 значений. Задача усложнилась, теперь промежуток нужен в 2 месяца подряд. Спасибо большое. ... |
|||
:
Нравится:
Не нравится:
|
|||
14.09.2020, 07:28 |
|
Sql даты 2
|
|||
---|---|---|---|
#18+
antonkuzmenkov Задача усложнилась, теперь промежуток нужен в 2 месяца подряд. Спасибо большое. Зряплату за тебя не нужно получить? ... |
|||
:
Нравится:
Не нравится:
|
|||
14.09.2020, 08:04 |
|
|
start [/forum/topic.php?fid=46&gotonew=1&tid=1685656]: |
0ms |
get settings: |
11ms |
get forum list: |
14ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
41ms |
get topic data: |
12ms |
get first new msg: |
8ms |
get forum data: |
3ms |
get page messages: |
46ms |
get tp. blocked users: |
2ms |
others: | 252ms |
total: | 397ms |
0 / 0 |