Oracle多行数据合并为一行数据并将列数据转为字段名的方法
实现查询效果
原数据
FZ | PROJECT | VALUE |
---|---|---|
1 | 电脑 | $1600 |
1 | 手机 | $12 |
1 | 导管 | $1 |
2 | 电脑 | $2 |
2 | 手机 | $22 |
方式一:MAX()
数据效果
FZ | 电脑 | 手机 | 导管 |
---|---|---|---|
1 | $1600 | $12 | $1 |
2 | $2 | $22 |
SQL
根据FZ字段筛选并分组,MAX支持字符内容,SUN()同样支持,但是只能是数字类型。
此方法没有数据库类型限制,MySQL、Oracle、达梦均可。
方式二:LISTAGG()
数据效果
FZ | PROJECT |
---|---|
1 | 电脑,手机,导管 |
此方法仅仅是合并列内容,便于整合。
listagg函数是在oracle11g后新增的,是一个实现字符串聚合的内建函数。也可以实现行转列的功能,将某个字段的多行数据合并成一条。
用法说明:
LISTAGG('需要拼接的数据表中的字段','分隔符') WITHIN GROUP( ORDER BY '同前面,需要拼接的数据表中的字段')
用法类似聚合函数,通过Group by语句,把每个Group的一个字段,拼接起来。
方式三:WM_CONCAT()
数据效果
FZ | PROJECT |
---|---|
1 | 电脑,手机,导管 |
2 | 电脑,手机 |
此方法与方法二相关相同,但适合于Oracle数据库。