鸿 网 互 联 www.68idc.cn

当前位置 : 服务器租用 > 数据库 > oracle > >

oracle怎样行列转置

来源:互联网 作者:佚名 时间:2022-06-27 08:26
oracle行列转置的方法:1、利用pivot()函数行转列,语法为“pivot(聚合函数 for 列名 in(类型))”;2、利用unpivot()函数列转行,语法为“unpivot(列名 for 列名 in(类型))”。 本教程操作环境:

oracle行列转置的方法:1、利用pivot()函数行转列,语法为“pivot(聚合函数 for 列名 in(类型))”;2、利用unpivot()函数列转行,语法为“unpivot(列名 for 列名 in(类型))”。

本教程操作环境:Windows10系统、Oracle 11g版、Dell G3电脑。

oracle怎样行列转置

以前接触过通用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怎样行列转置的详细内容,更多请关注鸿网互联其它相关文章!

【本文由:阿里云代理 http://www.56aliyun.com 复制请保留原URL】
上一篇:oracle中in和or的区别是什么
下一篇:没有了
网友评论
<