欢迎投稿

今日深度:

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

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


目录
  • 实现查询效果
    • 原数据
  • 方式一:MAX()
    • 数据效果
    • SQL
  • 方式二:LISTAGG()
    • 数据效果
  • 方式三:WM_CONCAT()
    • 数据效果
  • 总结 

    实现查询效果

    原数据

    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多行数据合并一行数据内容请搜索PHP之友以前的文章或继续浏览下面的相关文章希望大家以后多多支持PHP之友!

    您可能感兴趣的文章:
    • oracle实现将字段按逗号拼接/按逗号分为多行实例代码
    • oracle数据库实现按多个字段排序
    • 如何在Oracle数据库中更新CLOB字段
    • Oracle修改字段长度及属性的方法
    • Oracle单个字段多记录拼接方式

    www.htsjk.Com true http://www.htsjk.com/oracle/47908.html NewsArticle Oracle多行数据合并为一行数据并将列数据转为字段名三种方式, 目录 实现查询效果 原数据 方式一:MAX() 数据效果 SQL 方式二:LISTAGG() 数据效果 方式三:WM_CONCAT() 数据效果 总结 实现查...
    评论暂时关闭