oracle行列转置的方法:1、利用pivot()函数行转列,语法为“pivot(聚合函数 for 列名 in(类型))”;2、利用unpivot()函数列转行,语法为“unpivot(列名 for 列名 in(类型))”。
本教程操作环境:Windows10系统、Oracle 11g版、Dell G3电脑。
以前接触过通用SQL中的行列转置,行转列使用聚合函数sum | max 然后结合case when then else end 语句就可以实现,而列转行使用union或union all来实现。这样做其实有点麻烦,而在oracle数据中,专门提供了这样的函数来实现行列转置功能。
同样可以使用通用SQL来实现行列转置,但是Oracle提供了专门的函数来处理行列转置,也就是使用pivot函数和unpivot函数,下面进行介绍。
1、pivot行转列
oracle数据库中提供pivot函数来实现行转列的功能,同样实现上面行转列的效果,SQL也可以这样写:
SELECT NAME AS 姓名, "'语文'", "'数学'", "'英语'" FROM stu_score pivot ( max( score ) FOR SUBJECT IN ( '语文', '数学', '英语' ) );
查询结果如下:
2、unpivot列转行
oracle中提供unpivot函数来实现列转行功能,实现同样的效果,SQL也可以这样写:
SELECT NAME AS 姓名, 月份,工资 FROM e_sal unpivot ( 工资 FOR 月份 IN ( M_1, M_2, M_3, M_4 ) );
查询结果如下:
推荐教程:《Oracle视频教程》
以上是oracle怎样行列转置的详细内容。更多信息请关注PHP中文网其他相关文章!