记录一个在oracle中多行转多列的函数,有一个项目近期到了收尾阶段,忽然客户说有一个成本分摊的统计表逻辑要调整,我一看需求瞬间头大了,其中比较麻烦的一段逻辑就是需要把单行的多列数据分割成多行,百度了一下方法,大概是这样的。
原数据结构如下:每个人会有多个成本分摊,最后需要汇总出每个成本中心的分摊金额
首先需要先把这每行数据分割一下,分割成一个成本分摊对应一行数据
select id,username,cca,shares,total*shares/100 as total
from table1
unpivot((cca,shares)
for smdm in (
(cca1,share1),
(cca2,share2),
(cca3,share3)))
查询结果如下:
其中上面sql中,(cca,shares) 为最终列的别名,数量和位置都与下面 in 中的一致;smdm 为分列的一个标识,可以把他查询出来看一下,
比如第一行,smdm为“CCA1_SHARE1”,我们后面就可以判断这行数据是根据CCA1列+SHARE1列转换出来的。
具体意义可以继续再看下官网的解释,额,我是看不懂....