Użyj agregacji:
select foreignKey, min(primaryKey)
from t
group by foreignKey;
Jeśli chcesz otrzymać losową wartość, możesz użyć keep
składnia:
select foreignKey,
min(primaryKey) keep (dense_rank first order by dbms_random.random)
from t
group by foreignKey;
A jeśli masz wiele kolumn, możesz użyć row_number()
lub skorelowane podzapytanie:
select t.*
from t
where t.primarykey = (select min(t2.primarykey) from t t2 where t2.foreignkey = t.foreignkey);