Oracle SQL枢轴查询

Oracle SQL枢轴查询

我有如下表所示的数据:


MONTH VALUE


1     100

2     200

3     300

4     400

5     500

6     600

我想编写一个SQL查询,以便给出结果如下:


MONTH_JAN MONTH_FEB MONTH_MAR MONTH_APR MONTH_MAY MONTH_JUN

100       200       300       400       500       600


慕雪6442864
浏览 601回答 2
2回答

白衣染霜花

Oracle 9i+支持:SELECT SUM(CASE WHEN t.month = 1 THEN t.value ELSE 0 END) AS JAN,        SUM(CASE WHEN t.month = 2 THEN t.value ELSE 0 END) AS FEB,        SUM(CASE WHEN t.month = 3 THEN t.value ELSE 0 END) AS MAR,        SUM(CASE WHEN t.month = 4 THEN t.value ELSE 0 END) AS APR,        SUM(CASE WHEN t.month = 5 THEN t.value ELSE 0 END) AS MAY,        SUM(CASE WHEN t.month = 6 THEN t.value ELSE 0 END) AS JUN  FROM YOUR_TABLE t您只列出两列-类似这样的内容可能应该按年分组。有ANSI支点(和UNPIVOT)语法,但Oracle直到11g才支持它。在9i之前,您必须用Oracle特定的解码替换case语句。

月关宝盒

Oracle 11g及以上从Oracle 11g开始,您现在可以使用PIVOT为实现这一结果而采取的行动:create table tq84_pivot (   month number,   value number);insert into tq84_pivot values(1, 100);insert into tq84_pivot values(2, 200);insert into tq84_pivot values(3, 300);   insert into tq84_pivot values(4, 400);insert into tq84_pivot values(5, 500);insert into tq84_pivot values(6, 600);   --insert into tq84_pivot values(1, 400);insert into tq84_pivot values(2, 350);insert into tq84_pivot values(4, 150);select    *from   tq84_pivotpivot (    sum (value) as sum_value for      (month) in (1 as month_jan,                  2 as month_feb,                  3 as month_mar,                  4 as month_apr,                  5 as month_mai,                  6 as month_jun,                  7 as month_jul,                  8 as month_aug,                  9 as month_sep,                 10 as month_oct,                 11 as month_nov,                 12 as month_dec));
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

MySQL
Oracle