Трябва да използвате PIVOT
. Можете да използвате или СТАТИЧНА ОСВЕТНА, където знаете стойностите на колоните за трансформиране, или ДИНАМИЧНА ОСНОВНА, където колоните са неизвестни до момента на изпълнение.
Статична осова точка (Вижте SQL Fiddle с демонстрация ):
select *
from
(
select memid, Condition_id, Condition_Result
from t
) x
pivot
(
sum(condition_result)
for condition_id in ([C1], [C2], [C3], [C4])
) p
Динамична ос (Вижте SQL Fiddle с демонстрация ):
DECLARE @cols AS NVARCHAR(MAX),
@query AS NVARCHAR(MAX)
SET @cols = STUFF((SELECT distinct ',' + QUOTENAME(c.condition_id)
FROM t c
FOR XML PATH(''), TYPE
).value('.', 'NVARCHAR(MAX)')
,1,1,'')
set @query = 'SELECT memid, ' + @cols + ' from
(
select MemId, Condition_id, condition_result
from t
) x
pivot
(
sum(condition_result)
for condition_id in (' + @cols + ')
) p '
execute(@query)
И двете ще генерират едни и същи резултати.