Od STUDY_VALUE
kolumna wydaje się być ciągiem, musisz użyć max()
lub min()
funkcja agregująca na wartościach:
SELECT *
FROM
(
SELECT STUDYID, STUDY_VALUE, STUDY_PARAMETER
FROM STUDY_INFO
)
PIVOT
(
MAX(STUDY_VALUE)
FOR (STUDY_PARAMETER) IN ('Age Unit' AS AGE_UNIT,
'Age Group' AS AGE_GROUP,
'Trial Type' AS TRIAL_TYPE)
);
Zobacz SQL Fiddle z wersją demonstracyjną