oracle行列转换

时间:2024-03-30 11:56:09

行列转换的几种写法

列转行:

1.最简单的写法,使用关键字PIVOT

语法:SELECT * FROM TABLENAME PIVOT(MAX(LIST1) FOR LIST2 IN (VALUES1,VALUES2,VALUES3,VALUES4))

例子:

 oracle行列转换

实现行列转换效果:

 oracle行列转换

代码:SELECT * FROM S PIVOT(MAX(AMT) FOR Q IN (1,2,3,4))

2. 使用分析函数load/lag进行行列转换

代码:

SELECT S.Y, S.AMT Q1, S.LD1 Q2, S.LD2 Q3, S.LD3 Q4

  FROM (SELECT S.*,

               LEAD(S.AMT, 1) OVER(PARTITION BY S.Y ORDER BY S.Q) LD1,

               LEAD(S.AMT, 2) OVER(PARTITION BY S.Y ORDER BY S.Q) LD2,

               LEAD(S.AMT, 3) OVER(PARTITION BY S.Y ORDER BY S.Q) LD3

          FROM S) S

 WHERE S.Q = 1

 oracle行列转换

3. 使用decode函数进行行列转换

代码:

SELECT S.Y,

       SUM(DECODE(S.Q, 1, AMT, NULL)) Q1,

       SUM(DECODE(S.Q, 2, AMT, NULL)) Q2,

       SUM(DECODE(S.Q, 3, AMT, NULL)) Q3,

       SUM(DECODE(S.Q, 4, AMT, NULL)) Q4

  FROM S

 GROUP BY S.Y

 oracle行列转换

4.部分关联

代码:

SELECT S.Y, S.AMT Q1, A.AMT Q2, B.AMT Q3, C.AMT Q4

   FROM S,

        (SELECT * FROM S WHERE S.Q = 2) A,

        (SELECT * FROM S WHERE S.Q = 3) B,

        (SELECT * FROM S WHERE S.Q = 4) C

  WHERE S.Y = A.Y

    AND S.Y = B.Y

    AND S.Y = C.Y

    AND S.Q=1

 oracle行列转换

行转列:UNPIVOT

 代码:WITH A AS (SELECT * FROM S PIVOT(MAX(AMT) FOR Q IN (1 Q1,2 Q2,3 Q3,4 Q4))) SELECT * FROM A UNPIVOT(AMT FOR Q IN (Q1,Q2,Q3,Q4))

 oracle行列转换