将同列多行的值转换成一个字符串显示

本文介绍了一种使用SQL的SYS_CONNECT_BY_PATH函数和WM_CONCAT函数来处理数据分组的方法,通过具体实例展示了如何将同一列中的不同行值进行合并,并提供了两种不同的实现方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1. -- 原始数据   
  2. -- a   111   
  3. -- b   222   
  4. -- a   333   
  5. -- a   444   
  6. -- b   555   
  7. -- 最终结果   
  8. -- a   111*333*444   
  9.   
  10. SELECT   
  11. L4.L_TIME  
  12. ,MAX(SUBSTR(L4.分组内容,2)) 最终字段值  
  13. FROM(  
  14.         SELECT   
  15.         L3.L_TIME  
  16.         ,SYS_CONNECT_BY_PATH(L3.L_CONTENT,'*'AS 分组内容  
  17.         FROM(  
  18.                 SELECT  
  19.                 L2.L_TIME  
  20.                 ,L2.L_CONTENT  
  21.                 ,L2.L_TIME||L2.分组内编号 AS 分组字段加编号,L2.L_TIME||(L2.分组内编号-1) AS 上级分组字段加编号  
  22.                 FROM(  
  23.                         SELECT   
  24.                         L1.L_TIME   -- 分组依据   
  25.                         ,L1.L_CONTENT    -- 同一列中 要合并的不同行 的值  
  26.                         ,ROW_NUMBER() OVER (PARTITION BY L1.L_TIME ORDER BY L1.L_CONTENT ASC) 分组内编号   
  27.                         FROM LOGS L1  
  28.                 ) L2  
  29.         ) L3  
  30.         START WITH L3.上级分组字段加编号 LIKE '%0'   
  31.         CONNECT BY PRIOR L3.分组字段加编号=L3.上级分组字段加编号  
  32. ) L4  
  33.    
  34. WHERE L_TIME='111'  
  35. GROUP BY L4.L_TIME  

 还有另外一种方式,如果只返回单值的话可以用以下方式
select wm_concat(name) name from mytest; --默认是以,符号进行分割的;再配上replace()函数可以对默认的分隔进行修改

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值