у меня короткий вопрос
select
*
from
(
select 1 do_switch, 'abc', '2001-01-01'::TIMESTAMP
union all
select 0 do_switch, 'xyz', '2001-01-01'::TIMESTAMP
union all
select 1 do_switch, 'xyz', '2001-02-01'::TIMESTAMP
union all
select 0 do_switch, 'bcd', '2001-01-01'::TIMESTAMP
union all
select 0 do_switch, 'bcd', '2001-02-01'::TIMESTAMP
union all
select 0 do_switch, 'bcd', '2001-03-01'::TIMESTAMP
union all
select 0 do_switch, 'bcd', '2001-04-01'::TIMESTAMP
union all
select 0 do_switch, 'bcd', '2001-05-01'::TIMESTAMP
union all
select 0 do_switch, 'bcd', '2001-06-01'::TIMESTAMP
union all
select 0 do_switch, 'bcd', '2001-07-01'::TIMESTAMP
union all
select 1 do_switch, 'bcd', '2001-08-01'::TIMESTAMP
union all
select 0 do_switch, 'bcd', '2001-09-01'::TIMESTAMP
union all
select 0 do_switch, 'bcd', '2001-10-01'::TIMESTAMP
union all
select 0 do_switch, 'bcd', '2001-11-01'::TIMESTAMP
union all
select 1 do_switch, 'bcd', '2001-12-01'::TIMESTAMP
) data_set
в конце он должен дать мне набор результатов, где у меня есть дополнительный столбец, который является уникальным числом для каждой "группы", начиная с 1/0 и заканчиваядо последней 0 записи для того же имени
результат
введите описание изображения здесь
Могу ли я добиться этого с помощьюоконная функция?я пробовал с другим плотным_ранком и row_number с предшествующим и т. д., но ничего не помогло, спасибо