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

来源:互联网 发布:55网络电视 编辑:程序博客网 时间:2024/04/30 02:19
  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()函数可以对默认的分隔进行修改

1 0
原创粉丝点击