Рішення bilinkc працює чудово, але я думав, що я також викину шахту. Це однакова вартість, але може бути швидшою (або повільніше, я її не перевіряв). Різниця полягає в тому, що він використовує First_Value замість Row_Number. Оскільки нас цікавить лише перша цінність, на мою думку це більш прямо.
SELECT ID, Val, Kind FROM
(
SELECT First_Value(ID) OVER (PARTITION BY Val ORDER BY Kind) First, ID, Val, Kind
FROM mytable
)
WHERE ID = First;
Дані тесту.
--drop table mytable;
create table mytable (ID Number(5) Primary Key, Val Number(5), Kind Number(5));
insert into mytable values (1,1337,2);
insert into mytable values (2,1337,1);
insert into mytable values (3,3,4);
insert into mytable values (4,3,4);
Якщо ви віддаєте перевагу, ось еквівалент CTE.
WITH FirstIDentified AS (
SELECT First_Value(ID) OVER (PARTITION BY Val ORDER BY Kind) First, ID, Val, Kind
FROM mytable
)
SELECT ID, Val, Kind FROM FirstIdentified
WHERE ID = First;