写在前面
今天我们来学习一个稍微新鲜点的关键词,那就是Oracle数据库中的PIVOT,通过这个函数我们可以进行更方便的行转列。
下面就一起来看一下吧。
Oracle数据库之PIVOT实现行转列
Oracle数据库中的PIVOT函数,是在版本11g中新增的一个功能,所以如果你是在Oracle11g以下的,这个功能可能会让你想感觉升级一下体验体验。
假设一下,我们现在有一个人员表,在其中存着三个字段信息,分别是姓名,科目,学分。
比如下面的这个数据结构;
姓名 科目 学分
张三 高数 5
张三 计算机 6
赵四 计算机 5
赵四 高数 4
有了上面的这个数据结构,自然就有了行转列的需求条件,那么现在我们就想将这个结构转化成 姓名,高数,计算机。
比如下面的这个数据结构
姓名 高数 计算机
张三 5 6
赵四 5 4
同时在高数和计算机下面,展示相应的学分值。
如果我们使用老办法的话,就只能通过decode等函数来配合操作才可以。
现在有了PIVOT函数,应该如何实现呢?
来看一下下面的SQL先:
select * from (select username, kemu, xuefen from user) pivot(sum(xuefen) for kemu in (jisuanji AS jisuanji, gaoshu AS gaoshu))
通过这个SQL,我们就可以得到一个行转列的值。
可见PIVOT函数在行转列的过程中还是很顺利的。
通过函数内的参数,其中使用了sum函数来聚合学分内容,然后将学分内容映射到不同科目下,以此来得到想要的结果。
总结
今天我们来学习了Oracle数据库中的PIVOT,是不是感到使用这个函数实现行转列的需求更加方便了,那就对了,不足的地方就是还得升级Oracle,不说了,升级Oracle去了。