zoukankan      html  css  js  c++  java
  • wm_concat()的用法(转)

    wm_concat()简介  (转)

    介绍:其函数在Oracle 10g推出,在10g版本中,返回字符串类型,在11g版本中返回clob类型。

    括号里面的参数是列,而且可以是多个列的集合,也就是说在括号里面可以自由地用‘||’合并字符串。

    用法1: Select aaa, wmsys.wm_concat(bbb || '(' || ccc || ')' ) from table group by aaa

    用法2: Select aaa, wmsys.wm_concat(bbb || '(' || ccc || ')' ) over(partition by aaa) from table 

    三、应用实例:

    3.1、创建表 CREATE TABLE TESTAGG

    (  

      A VARCHAR2(20),

      B VARCHAR2(20),

      C VARCHAR2(20)

    )

    3.2、初始化数据

    INSERT INTO "TESTAGG" (A, B, C) VALUES ('1', 'B1','C1')

    INSERT INTO "TESTAGG" (A, B, C) VALUES ('1', 'B2','C2')

    INSERT INTO "TESTAGG" (A, B, C) VALUES ('1', 'B3','C3')

    INSERT INTO "TESTAGG" (A, B, C) VALUES ('2', 'B4','C4')

    INSERT INTO "TESTAGG" (A, B, C) VALUES ('2', 'B5','C5')

    INSERT INTO "TESTAGG" (A, B, C) VALUES ('3', 'B6','C6')

    3.3、wm_concat()用法

    select a,wm_concat(b|| '(' || c || ')') as bc from testagg group by a order by a

    1  <CLOB>--B1(C1),B2(C2),B3(C3)

    2  <CLOB>--B4(C4),B5(C5)

    3  <CLOB>--B6(C6)

    若要转化成string可以用to_char()函数。

    3.4、 LISTAGG()用法

    select a,LISTAGG(b,',' ) within group(order by a) as bc from testagg group by a

    1 B1,B2,B3

    2 B4,B5

    3 B6

    注意:但当数据量比较大时,一般clob字段超过4000,却报ORA-01489:字符串连接的结果过长。有兴趣的小伙伴可以研究下解决办法。

  • 相关阅读:
    20070521_新疆出差纪实
    有想应聘技术咨询顾问职位的朋友请看过来
    Access:運作必須查詢3/19
    我們是好朋友1/3
    小說學習1/22
    [Asp.net]動態設定標簽寬度2/22
    [Asp.net]HyperLinkColumn應用2/28
    [Asp.net]重啟IIS2/29
    [Asp.NET]水晶報表與網路密碼2/27
    把學習量化3/6
  • 原文地址:https://www.cnblogs.com/ZJ0065/p/10504512.html
Copyright © 2011-2022 走看看