Oracle多行数据合并为一行数据并将列数据转为字段名三种方式

 更新时间:2024年06月28日 09:12:35   作者:herozhi0821  
怎么合并多行记录的字符串,一直是oracle新手喜欢问的SQL问题之一,下面这篇文章主要给大家介绍了关于Oracle多行数据合并为一行数据并将列数据转为字段名的三种方式,文中通过代码介绍的非常详细,需要的朋友可以参考下

实现查询效果

原数据

FZPROJECTVALUE
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()

数据效果

FZPROJECT
1电脑,手机,导管

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

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数据库。

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

总结 

到此这篇关于Oracle多行数据合并为一行数据并将列数据转为字段名的文章就介绍到这了,更多相关Oracle多行数据合并一行数据内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 在Oracle数据库中同时更新两张表的简单方法

    在Oracle数据库中同时更新两张表的简单方法

    这篇文章主要介绍了在Oracle数据库中同时更新两张表的简单方法,同时介绍了一种差异性合并更新的方法,需要的朋友可以参考下
    2015-11-11
  • Oracle存储过程里操作BLOB的字节数据的办法

    Oracle存储过程里操作BLOB的字节数据的办法

    该篇文章介绍了如何在Oracle存储过程中操作BLOB的字节数据,作者研究了如何获取BLOB的字节长度、如何使用DBMS_LOB包进行BLOB操作、如何进行字节级操作以及如何使用UTL_RAW包,感兴趣的朋友一起看看吧
    2025-03-03
  • oracle指定排序的方法详解

    oracle指定排序的方法详解

    本篇文章是对oracle指定排序的方法进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • 详解Oracle中sqlldr的具体用法

    详解Oracle中sqlldr的具体用法

    这篇文章主要介绍了详解Oracle中sqlldr的用法,SQLLDR可以在极短的时间内加载数量庞大的数据,这是一个非常有用的工具,可用于从多种平面文件格式向Oracle数据库中加载数据,需要的朋友可以参考下
    2023-07-07
  • Orcale权限、角色查看创建方法

    Orcale权限、角色查看创建方法

    查看当前用户拥有的系统权限、创建用户、授予拥有会话的权限、授予无空间限制的权限等等,感兴趣的朋友可以参考下哈,希望对你有所帮助
    2013-05-05
  • 使用 Oracle 数据库进行基于 JSON 的应用程序开发

    使用 Oracle 数据库进行基于 JSON 的应用程序开发

    本文档概述了 Oracle Database 19c 和 21c 版本中包含的功能和增强功能以​​及相关的 Oracle 技术,以及为什么 Oracle Database 中的 JSON 功能非常适合满足当今开发人员寻求文档存储来持久化、查询和处理应用程序数据的需求,感兴趣的朋友一起看看吧
    2025-04-04
  • Oracle性能究极优化 下

    Oracle性能究极优化 下

    Oracle性能究极优化 下...
    2007-03-03
  • ORACLE数据表分析

    ORACLE数据表分析

    这篇文章介绍了ORACLE进行数据表分析的方法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-05-05
  • 解决The Network Adapter could not establish the conn问题

    解决The Network Adapter could not establish the conn问题

    这篇文章主要介绍了解决The Network Adapter could not establish the conn问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • 一些Oracle数据库中的查询优化建议综合

    一些Oracle数据库中的查询优化建议综合

    这篇文章主要介绍了一些Oracle数据库中的查询优化建议综合,包括in和not in的使用等一些细节上的使用建议,需要的朋友可以参考下
    2016-01-01

最新评论