ORACLE下的多列转多行函数

记录一个在oracle中多行转多列的函数,有一个项目近期到了收尾阶段,忽然客户说有一个成本分摊的统计表逻辑要调整,我一看需求瞬间头大了,其中比较麻烦的一段逻辑就是需要把单行的多列数据分割成多行,百度了一下方法,大概是这样的。

 原数据结构如下:每个人会有多个成本分摊,最后需要汇总出每个成本中心的分摊金额

ORACLE下的多列转多行函数_第1张图片

首先需要先把这每行数据分割一下,分割成一个成本分摊对应一行数据

select id,username,cca,shares,total*shares/100 as total
from table1
    unpivot((cca,shares)
    for smdm in (
        (cca1,share1),
        (cca2,share2),
        (cca3,share3)))

查询结果如下:

ORACLE下的多列转多行函数_第2张图片

其中上面sql中,(cca,shares) 为最终列的别名,数量和位置都与下面 in 中的一致;smdm 为分列的一个标识,可以把他查询出来看一下,

ORACLE下的多列转多行函数_第3张图片

比如第一行,smdm为“CCA1_SHARE1”,我们后面就可以判断这行数据是根据CCA1列+SHARE1列转换出来的。

具体意义可以继续再看下官网的解释,额,我是看不懂....

ORACLE下的多列转多行函数_第4张图片

你可能感兴趣的:(oracle,oracle)