当前位置:首页 > 数据库 > 正文内容

Oracle多行数据合并为一行数据并将列数据转为字段名的方法

2024-11-30数据库7

实现查询效果

原数据

FZPROJECTVALUE
1电脑$1600
1手机$12
1导管$1
2电脑$2
2手机$22

方式一:MAX()

数据效果

FZ电脑手机导管
1$1600$12$1
2$2$22

SQL

根据FZ字段筛选并分组,MAX支持字符内容,SUN()同样支持,但是只能是数字类型。

1
2
3
4
5
6
SELECT FZ,
    MAX(CASE WHEN PROJECT = '电脑' THEN VALUE END) 电脑,
    MAX(CASE WHEN PROJECT = '手机' THEN VALUE END) 手机,
    MAX(CASE WHEN PROJECT = '导管' THEN VALUE END) 导管
FROM TABLE01
GROUP BY FZ

此方法没有数据库类型限制,MySQL、Oracle、达梦均可。

方式二:LISTAGG()

数据效果

FZPROJECT
1电脑,手机,导管

此方法仅仅是合并列内容,便于整合。

1
2
3
SELECT FZ,LISTAGG(PROJECT,',') PROJECT
FROM TABLE01
WHERE FZ = 1;

listagg函数是在oracle11g后新增的,是一个实现字符串聚合的内建函数。也可以实现行转列的功能,将某个字段的多行数据合并成一条。

用法说明:

  • LISTAGG('需要拼接的数据表中的字段','分隔符') WITHIN GROUP( ORDER BY '同前面,需要拼接的数据表中的字段')

  • 用法类似聚合函数,通过Group by语句,把每个Group的一个字段,拼接起来。

方式三:WM_CONCAT()

数据效果

FZPROJECT
1电脑,手机,导管
2电脑,手机

此方法与方法二相关相同,但适合于Oracle数据库。

1
2
3
4
SELECT FZ,WM_CONCAT(PROJECT,',') PROJECT
FROM TABLE01
--WHERE FZ = 1
GROUP BY FZ;