Oracle 10g WM_CONCAT行转列函数用法及注意点

系统 2515 0

 

WM_CONCAT(colName)为Oracle 10g中行数据转列数据的内置函数,执行效果如下

表T

      
           A    B

------------

   
      
      1    2

   1    3

   1    4

   2    1

   2    3
    

执行语句 :

      
        SELECT
      
       A, WM_CONCAT(B) B 
      
        FROM
      
       T 
      
        GROUP
      
      
        BY
      
       A
    

执行结果:

      
           A    B

---------------

   
      
      1    2,3,4

   2    1,3
    

 

注意:

  当在包体内使用行转列时,WM_CONCAT(colName)可以使用,但WM_CONCAT(DISTINCT colName)会在包编译时会报错,

  例如,在某一包的某一存储过程中有如下语句:

      
         1
      
      
        UPDATE
      
      
         D_LOWAREA L


      
      
         2
      
      
        SET
      
       L.BYQXH 
      
        =
      
       (
      
        SELECT
      
      
        /*
      
      
        +index(b)
      
      
        */
      
      
         3
      
                          WM_CONCAT(
      
        DISTINCT
      
      
         XH.XHMC)


      
      
         4
      
      
        FROM
      
      
         OLIVE.OL$_ASSOCIATIONS A,


      
      
         5
      
      
                                 PMSBI.F_SB_SBXX_BASIC  B,


      
      
         6
      
      
                                 PMSBI.D_XH             XH


      
      
         7
      
      
        WHERE
      
       A.A 
      
        IN
      
      
         (L.PDBYQ1, L.PDBYQ2, L.PDBYQ3)


      
      
         8
      
      
        AND
      
       A.B 
      
        =
      
      
         B.SBBH


      
      
         9
      
      
        AND
      
       B.XHDM 
      
        !=
      
      
        '
      
      
        wz
      
      
        '
      
      
        10
      
      
        AND
      
       B.XHDM 
      
        =
      
      
         XH.XHDM);


      
      
        11
      
      
        COMMIT
      
      ;
    

 

      编译时会报如下错误:

     PL/SQL:ORA-30482:DISTINCT option not allowed for this function.

 

解决方案:

  使用动态SQL(字符串中有单引号由两个单引号表示):

      
         1
      
      
        EXECUTE
      
      
         IMMEDIATE 


      
      
         2
      
      
        '
      
      
        UPDATE D_LOWAREA L


      
      
         3
      
      
              SET L.BYQXH = (SELECT /*+index(b)*/


      
      
         4
      
      
                              WMSYS.WM_CONCAT(DISTINCT XH.XHMC)


      
      
         5
      
      
                               FROM OLIVE.OL$_ASSOCIATIONS A,


      
      
         6
      
      
                                    PMSBI.F_SB_SBXX_BASIC  B,


      
      
         7
      
      
                                    PMSBI.D_XH             XH


      
      
         8
      
      
                              WHERE A.A IN (L.PDBYQ1, L.PDBYQ2, L.PDBYQ3)


      
      
         9
      
      
                                AND A.B = B.SBBH


      
      
        10
      
      
                                AND B.XHDM != 
      
      
        ''
      
      
        wz
      
      
        ''
      
      
        11
      
      
                                AND B.XHDM = XH.XHDM)
      
      
        '
      
      
        ;


      
      
        12
      
      
        COMMIT
      
      ;
    

 

PS:Oracle 11g以上版本可以用LISTAGG实现行转列,写法如下:

      
        SELECT
      
       A, LISTAGG(B, 
      
        '
      
      
        ,
      
      
        '
      
      ) WITHIN 
      
        GROUP
      
      (
      
        ORDER
      
      
        BY
      
       B) B 
      
        FROM
      
       T 
      
        GROUP BY
      
       A
    

 

Oracle 10g WM_CONCAT行转列函数用法及注意点


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论