Hmmm . . . Anda bisa mendapatkan tanggal 44 paling awal setelah tanggal non-44 terakhir menggunakan:
select min(start_date)
from t
where t.start_date > (select max(t2.start_date)
from t t2
where t2.step_key <> 44
);
Saya pikir ini yang Anda minta.
Anda dapat menggunakan fungsi jendela juga. Dengan asumsi bahwa baris terbaru adalah "44":
select t.*
from (select t.*,
row_number() over (order by start_date) as seqnum,
row_number() over (partition by step_key order by start_date) as seqnum_sk
from t
) t
where step_key = 44 and seqnum = seqnum_sk
order by start_date
fetch first 1 row only;