ORACLE下的多列转多行函数

记录一个在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列转换出来的。

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

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值