Jest to jeden ze sposobów za pomocą self-join i union
.
select t1.val
from t t1
join t t2 on t1.val = t2.val-1
union
select t2.val
from t t1
join t t2 on t1.val = t2.val-1
order by 1
Edycja:zdałem sobie sprawę, że można to zrobić za pomocą jednego zapytania zamiast używania union
.
select distinct t1.val
from t t1
join t t2 on t1.val = t2.val-1 or t1.val = t2.val+1
order by 1