Вы можете комбинировать оконные функции LAG()
и SUM()
, чтобы разделить строки на группы в соответствии с вашей логикой.После разделения вычисление минимального и максимального значений становится тривиальным.
Например:
select
min(year_validity) as year_min,
max(year_validity) as year_max,
min(value1) as value1,
min(value2) as value2
from (
select
*,
sum(init) over(order by year_validity) as grp
from (
select *,
case when not ( (value1, value2) = (
lag(value1) over(order by year_validity),
lag(value2) over(order by year_validity)
) ) then 1 else 0 end as init
from tabla
) x
) y
group by grp
order by value1, value2
Результат:
year_min year_max value1 value2
-------- -------- ------ ------
2004 2004 A B
2007 2008 A B
2006 2006 A C
Для записи сценарий данных для этогодело:
create table tabla (
year_validity int,
value1 varchar(10),
value2 varchar(10)
);
insert into tabla (year_validity, value1, value2) values (2004, 'A', 'B');
insert into tabla (year_validity, value1, value2) values (2006, 'A', 'C');
insert into tabla (year_validity, value1, value2) values (2007, 'A', 'B');
insert into tabla (year_validity, value1, value2) values (2008, 'A', 'B');