Можно создать дубликат:
dynamic sql pivot in sql serverГруппировка данных по столбцам
У меня есть таблица под названием Col_values и Col_ID является полем идентификации данных выглядит следующим образом:
Val_ID Col_ID Value
76951792 3 Closed
76951791 3 Closed
76951790 25 Open
76951789 25 Closed
76951792 1 US
76951791 1 Canada
и другая таблица называется Et_Col, и данные выглядят так:
Col_ID Col_Name D_ID
3 Status 1
25 Status 2
1 Country 1
Я хочу, чтобы выход как:
Val_ID Status Country
76951792 Closed US
76951791 Closed Canada
76951790 Open Null
76951789 Closed Null
Так что я написал курсор, чтобы получить выход и курсор возвращает заявление, как:
Select val_ID
,max(case when Col_ID = 3 then Value end) as Status
,max(case when Col_ID = 25 then Value end) as Status
,max(CASE WHEN Col_ID = 1 THEN VALUE END) AS Country
From Col_values
Group by Val_ID
это дает мне выход, как:
Val_ID Status Status Country
76951792 Closed Null US
76951791 Closed Null Canada
76951789 Null Closed Null
76951790 Null Open Null
Как это исправить?
Вы знаете термин нормализация? –
Это можно сделать с помощью динамической сводной таблицы: http://stackoverflow.com/questions/8327261/dynamic-sql-pivot-in-sql-server – JeffO