Можете да завъртите таблицата, като използвате row_number() като източник на имена на колони:
select *
from
(
select ref,
name,
link,
row_number() over (partition by ref, name order by link) rn
from table1
) s
pivot (min (link) for rn in ([1], [2], [3], [4])) pvt
Просто разширете списъка с числа, ако имате повече редове.
Тестът на живо е @ Sql Fiddle .