Oracle数据库之PIVOT实现行转列

300 阅读2分钟

「这是我参与2022首次更文挑战的第22天,活动详情查看:2022首次更文挑战

写在前面

今天我们来学习一个稍微新鲜点的关键词,那就是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去了。