【Oracle】行转列的函数wm_concat,listagg,xmlagg,pivot以及动态行转列

发布时间 2023-07-05 11:02:45作者: DbWong_0918

【Oracle】行转列的几种情况

表的数据如下
image

朴实无华的函数

1.wm_concat

使用格式:

select 分组字段,wm_concat(要转换的列名) from 表名 group by 分组字段

实例:

select it.Code,wm_concat(it.inv) from ttt20230705 it group by it.Code

image

2.listagg() within group()

使用格式:

select 分组字段,listagg(要转换的列名,',') within group(order by 要转换的列名) from 表名 group by 分组字段

实例:

select it.Code,listagg(it.inv,',') within group(order by it.inv) from ttt20230705 IT group by it.Code

image

3.xmlagg

本质就是listagg加强版,详情见这里

4.pivot(本质还是case when)

使用格式:

select * from 表名 pivot(聚合函数(转换的字段名) for Code in (转换的值1 AS 字段名1,转换的值2 AS 字段名2,转换的值3 AS 字段名3));

实例:

select * from ttt20230705 pivot(listagg(inv,',') for Code in ('AA' AS AA,'BB' AS BB,'CC' AS CC));

image

动态行转列(行固定)

基本思路就是使用存储过程对SQL进行拼接,通过执行SQL对数据查询出来,然后将数据做成表或者视图,然后查询出来

参考这个

动态行转列(行不固定)

这种是什么意思呢,就是我现在遇到的问题

在这五个表中的数据各有关联,可以连表对某个类别的数据属性进行查询,但是问题就在于,同一个大类下的所有小类各有各的属性,可能上一个属性名是备注的位置,下一个类别的对应位置属性名就是走向,且大部分都是不一样的,也就形成了,一个类别对应多个子类别,每个子类别对应多个属性名,每个属性名对应每个属性数据,但是存储属性名和属性数据的表数据内容并不是一样的,这就导致,可能我行转列出来的数据是一团乱麻,没有价值

这种情况,最后的解决方法就只有最暴力的枚举了,对每个查询出来的属性名和数据单独再查询一次,才能保证每个数据都是对的,即

select 
(select it.name from table2 it where it.a = t.a),
(select it.name from table2 it where it.a = t.b),
(select it.name from table2 it where it.a = t.c),
(select iit.data from table3 iit where iit.a = t.a),
(select iit.data from table3 iit where iit.a = t.b),
(select iit.data from table3 iit where iit.a = t.ab),
from table1 t