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()同样支持,但是只能是数字类型。
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()
数据效果
FZ | PROJECT |
---|---|
1 | 电脑,手机,导管 |
此方法仅仅是合并列内容,便于整合。
SELECT FZ,LISTAGG(PROJECT,',') PROJECT
FROM TABLE01
WHERE FZ = 1;
方式三:WM_CONCAT()
数据效果
FZ | PROJECT |
---|---|
1 | 电脑,导管 |
2 | 电脑,手机 |
此方法与方法二相关相同,但适合于Oracle数据库。
SELECT FZ,WM_CONCAT(PROJECT,') PROJECT
FROM TABLE01
--WHERE FZ = 1
GROUP BY FZ;
原文地址:https://blog.csdn.net/u014295903/article/details/132107649
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。