Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / Microsoft SQL Server [игнор отключен] [закрыт для гостей] / Можно ли сплющить данные так? / 3 сообщений из 3, страница 1 из 1
26.11.2019, 15:02
    #39894528
Hopfen_Artur
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Можно ли сплющить данные так?
Добрый день, есть такая таблица:

Date Status Duration2019-11-26 14:38:33.547 1 362019-11-26 14:38:25.687 0 92019-11-26 14:38:14.347 1 242019-11-26 14:38:13.220 0 192019-11-26 14:38:13.220 1 32

Можно ли соединить Status = 1 с Status = 0. Чтобы получилось так?:

Duration454332
...
Рейтинг: 0 / 0
26.11.2019, 15:25
    #39894544
Minamoto
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Можно ли сплющить данные так?
Hopfen_Artur, можно.

Например, так:

Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
SELECT Duration FROM (
SELECT Status, t.Duration + LEAD(Duration, 1, 0) OVER (ORDER BY t.Date DESC, t.Status ASC) AS Duration

FROM (VALUES(cast('2019-11-26 14:38:33.547' as datetime),	1,	36),
            (cast('2019-11-26 14:38:25.687' as datetime),	0,	9 ),
            (cast('2019-11-26 14:38:14.347' as datetime),	1,	24),
            (cast('2019-11-26 14:38:13.220' as datetime),	0,	19),
            (cast('2019-11-26 14:38:13.220' as datetime),	1,	32)) AS t (Date, Status, Duration)
) t
WHERE t.Status = 1
...
Рейтинг: 0 / 0
27.11.2019, 03:04
    #39894797
3unknown
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Можно ли сплющить данные так?
Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
declare @t table (Date datetime, Status int, Duration int)

insert @t 
VALUES(cast('2019-11-26 14:38:33.547' as datetime),	1,	36),
            (cast('2019-11-26 14:38:25.687' as datetime),	0,	9 ),
            (cast('2019-11-26 14:38:14.347' as datetime),	1,	24),
            (cast('2019-11-26 14:38:13.220' as datetime),	0,	19),
            (cast('2019-11-26 14:38:13.220' as datetime),	1,	32)

;with a as(
select* 
,row_number() over(order by 1/0) n
from @t
)
,b as (select*
,sum(status) over(order by n) gr
from a)
select sum(duration) duration
from b
group by gr
order by gr
...
Рейтинг: 0 / 0
Форумы / Microsoft SQL Server [игнор отключен] [закрыт для гостей] / Можно ли сплющить данные так? / 3 сообщений из 3, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]