如何将表从列转换为Oracle sql中的行

时间:2013-06-12 07:36:15

标签: sql oracle transpose

我在sql中有一个表,它有许多列,每列都有相同类型的数据。我想将表的列转换为行,以便所有数据都显示在1列中。我正在谈论的表格类型的一个例子:

ID    DATE    TEST_1    TEST_2    TEST_3
----------------------------------------
1     1jan12    98        66       77
2     2jan12    75        89       72

分为:

ID    DATE        TEST       SCORE
-----------------------------------
1     1jan12      TEST_1      98
1     1jan12      TEST_2      66
1     1jan12      TEST_3      77
2     2jan12      TEST_1      75
2     2jan12      TEST_2      89
2     2jan12      TEST_3      72

提前感谢任何建议或指示!

1 个答案:

答案 0 :(得分:4)

一种选择是使用'Union All':

SELECT ID, DATE, 'TEST_1' AS TEST, TEST_1 AS SCORE
FROM TABLE
UNION ALL
SELECT ID, DATE, 'TEST_2' AS TEST, TEST_2 AS SCORE
FROM TABLE
UNION ALL
SELECT ID, DATE, 'TEST_3' AS TEST, TEST_3 AS SCORE
FROM TABLE