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 使用sql获取数据库表、表的字段的多种方法

    oracle 使用sql获取数据库表、表的字段的多种方法

    使用sql获取数据库表,表的字段的方法有很多,本文整理了几个常用且实用的方法,需要的朋友可以参考下
    2013-11-11
  • Oracle对字段的增删改方法分享

    Oracle对字段的增删改方法分享

    这篇文章给大家分享了Oracle对字段的增删改语句,对大家日常操作Oracle非常实用,有需要的可以参考借鉴。
    2016-08-08
  • Oracle临时表空间删除和重建实现过程

    Oracle临时表空间删除和重建实现过程

    这篇文章主要介绍了Oracle临时表空间删除和重建实现过程,临时表空间是NOLOGGING模式以及它不保存永久类型对象,因此即使数据库损毁,做Recovery也不需要恢复Temporary Tablespace。下文更多详细内容介绍需要的小伙伴可以参考一下
    2022-03-03
  • Oracle判断是否需要重建索引的详细步骤

    Oracle判断是否需要重建索引的详细步骤

    Oracle数据库中的重建索引(Rebuild Index)是一个维护操作,用于更新或完全重构已有的索引结构,当索引损坏、性能下降或者需要优化时,可以执行此操作,本文给大家介绍了Oracle判断是否需要重建索引的详细步骤,需要的朋友可以参考下
    2024-08-08
  • Oracle 实现将查询结果保存到文本txt中

    Oracle 实现将查询结果保存到文本txt中

    这篇文章主要介绍了Oracle 实现将查询结果保存到文本txt中的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-02-02
  • Oracle中的高效SQL编写PARALLEL解析

    Oracle中的高效SQL编写PARALLEL解析

    这篇文章主要介绍了Oracle中的高效SQL编写PARALLEL解析,在Oracle中,PARALLEL(并行)方式最大化调用计算机资源来成倍提高数据分析效率,这个在Oracle 9i之后的版本可以使用,需要的朋友可以参考下
    2023-07-07
  • Oracle数据库聚合函数XMLAGG详解(全网最全)

    Oracle数据库聚合函数XMLAGG详解(全网最全)

    在SQL中,合函数用于对一组值进行计算并返回单一的值,这篇文章主要给大家介绍了关于Oracle数据库聚合函数XMLAGG的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-06-06
  • 深入Oracle的left join中on和where的区别详解

    深入Oracle的left join中on和where的区别详解

    本篇文章是对Oracle的left join中on和where的区别进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • Oracle数据库中 call 和 exec的区别

    Oracle数据库中 call 和 exec的区别

    在sqlplus中这两种方法都可以使用: exec pro_name(参数1..); call pro_name(参数1..); 但是这两者有什么区别呢?今天小编给大家介绍下oracle数据库中 call 和 exec的区别,感兴趣的朋友一起看看吧
    2016-09-09
  • Oracle使用dblink实现跨库访问的实例代码

    Oracle使用dblink实现跨库访问的实例代码

    dbLink是简称,全称是databaselink,database link是定义一个数据库到另一个数据库的路径的对象,database link允许你查询远程表及执行远程程序,本文给大家介绍了Oracle如何使用dblink实现跨库访问,需要的朋友可以参考下
    2024-03-03

最新评论