Oracle多行数据合并为一行数据并将列数据转为字段名三种方式
更新时间:2024年06月28日 09:12:35 作者:herozhi0821
怎么合并多行记录的字符串,一直是oracle新手喜欢问的SQL问题之一,下面这篇文章主要给大家介绍了关于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;
listagg函数是在oracle11g后新增的,是一个实现字符串聚合的内建函数。也可以实现行转列的功能,将某个字段的多行数据合并成一条。
用法说明:
- LISTAGG('需要拼接的数据表中的字段','分隔符') WITHIN GROUP( ORDER BY '同前面,需要拼接的数据表中的字段')
- 用法类似聚合函数,通过Group by语句,把每个Group的一个字段,拼接起来。
方式三:WM_CONCAT()
数据效果
| FZ | PROJECT |
|---|---|
| 1 | 电脑,手机,导管 |
| 2 | 电脑,手机 |
此方法与方法二相关相同,但适合于Oracle数据库。
SELECT FZ,WM_CONCAT(PROJECT,',') PROJECT FROM TABLE01 --WHERE FZ = 1 GROUP BY FZ;
总结
到此这篇关于Oracle多行数据合并为一行数据并将列数据转为字段名的文章就介绍到这了,更多相关Oracle多行数据合并一行数据内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
使用 Oracle 数据库进行基于 JSON 的应用程序开发
本文档概述了 Oracle Database 19c 和 21c 版本中包含的功能和增强功能以及相关的 Oracle 技术,以及为什么 Oracle Database 中的 JSON 功能非常适合满足当今开发人员寻求文档存储来持久化、查询和处理应用程序数据的需求,感兴趣的朋友一起看看吧2025-04-04
解决The Network Adapter could not establish the conn问题
这篇文章主要介绍了解决The Network Adapter could not establish the conn问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2023-02-02


最新评论