wmsys.wm_concat函数用法

今天在论坛的一个回帖里看到一个朋友用了wmsys.wm_concat这个函数,自己还不知道怎么用,就去百度了一下,大概内容如下。

============================================================================================

它的作用是以','链接字符。

 

例子如下:

 

[php] view plain copy
  1. SQL> create table idtable (id number,name varchar2(30));  
  2.   
  3.    
  4.   
  5. Table created  
  6.   
  7.    
  8.   
  9. SQL> insert into idtable values(10,'ab');  
  10.   
  11.    
  12.   
  13. 1 row inserted  
  14.   
  15.    
  16.   
  17. SQL> insert into idtable values(10,'bc');  
  18.   
  19.    
  20.   
  21. 1 row inserted  
  22.   
  23.    
  24.   
  25. SQL> insert into idtable values(10,'cd');  
  26.   
  27.    
  28.   
  29. 1 row inserted  
  30.   
  31.    
  32.   
  33. SQL> insert into idtable values(20,'hi');  
  34.   
  35.    
  36.   
  37. 1 row inserted  
  38.   
  39.    
  40.   
  41. SQL> insert into idtable values(20,'ij');  
  42.   
  43.    
  44.   
  45. 1 row inserted  
  46.   
  47. SQL> insert into idtable values(20,'mn');  
  48.   
  49.    
  50.   
  51. 1 row inserted  
  52.   
  53.    
  54.   
  55. SQL> select * from idtable;  
  56.   
  57.    
  58.   
  59.         ID NAME  
  60.   
  61. ---------- ------------------------------  
  62.   
  63.         10 ab  
  64.   
  65.         10 bc  
  66.   
  67.         10 cd  
  68.   
  69.         20 hi  
  70.   
  71.         20 ij  
  72.   
  73.         20 mn  
  74.   
  75.    
  76.   
  77. 6 rows selected  
  78.   
  79. SQL> select id,wmsys.wm_concat(name) name from idtable  
  80.   
  81.   2  group by id;  
  82.   
  83.    
  84.   
  85.         ID NAME  
  86.   
  87. ---------- --------------------------------------------------------------------------------  
  88.   
  89.         10 ab,bc,cd  
  90.   
  91.         20 hi,ij,mn  
  92.   
  93.    
  94.   
  95. SQL> select id,wmsys.wm_concat(name) over (order by id) name from idtable;  
  96.   
  97.    
  98.   
  99.         ID NAME  
  100.   
  101. ---------- --------------------------------------------------------------------------------  
  102.   
  103.         10 ab,bc,cd  
  104.   
  105.         10 ab,bc,cd  
  106.   
  107.         10 ab,bc,cd  
  108.   
  109.         20 ab,bc,cd,hi,ij,mn  
  110.   
  111.         20 ab,bc,cd,hi,ij,mn  
  112.   
  113.         20 ab,bc,cd,hi,ij,mn  
  114.   
  115.    
  116.   
  117. 6 rows selected  
  118.   
  119.    
  120.   
  121. SQL> select id,wmsys.wm_concat(name) over (order by id,name) name from idtable;  
  122.   
  123.    
  124.   
  125.         ID NAME  
  126.   
  127. ---------- --------------------------------------------------------------------------------  
  128.   
  129.         10 ab  
  130.   
  131.         10 ab,bc  
  132.   
  133.         10 ab,bc,cd  
  134.   
  135.         20 ab,bc,cd,hi  
  136.   
  137.         20 ab,bc,cd,hi,ij  
  138.   
  139.         20 ab,bc,cd,hi,ij,mn  
  140.   
  141.    
  142.   
  143. 6 rows selected  
  144.   
  145.    
  146.   
  147. --个人觉得这个用法比较有趣.  
  148.   
  149.    
  150.   
  151. SQL> select id,wmsys.wm_concat(name) over (partition by id) name from idtable;  
  152.   
  153.    
  154.   
  155.         ID NAME  
  156.   
  157. ---------- --------------------------------------------------------------------------------  
  158.   
  159.         10 ab,bc,cd  
  160.   
  161.         10 ab,bc,cd  
  162.   
  163.         10 ab,bc,cd  
  164.   
  165.         20 hi,ij,mn  
  166.   
  167.         20 hi,ij,mn  
  168.   
  169.         20 hi,ij,mn  
  170.   
  171.    
  172.   
  173. 6 rows selected  
  174.   
  175.    
  176.   
  177. SQL> select id,wmsys.wm_concat(name) over (partition by id,name) name from idtable;  
  178.   
  179.    
  180.   
  181.         ID NAME  
  182.   
  183. ---------- --------------------------------------------------------------------------------  
  184.   
  185.         10 ab  
  186.   
  187.         10 bc  
  188.   
  189.         10 cd  
  190.   
  191.         20 hi  
  192.   
  193.         20 ij  
  194.   
  195.         20 mn  
  196.   
  197.    
  198.   
  199. 6 rows selected 

你可能感兴趣的:(wmsys.wm_concat函数用法)