Detta är ett sätt att göra det med hjälp av self-join och 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
Edit:Jag insåg att detta kunde göras med en enda fråga istället för att använda 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