中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

oracle 12C wmsys.wm_concat()函數

發布時間:2020-08-05 07:47:46 來源:ITPUB博客 閱讀:200 作者:skyin_1603 欄目:關系型數據庫

    對于一些業務,需要連接函數把內容拼接文本文件的時候,借助合適的函數,非常重要,減少很多工作。
目前常用的連接函數有 wmsys.wm_concat()和 LISTAGG( )函數,當然還有看拼接內容的長度來選。
oracle數據庫中,還有一個根據版本選擇。最新的兩個版本中,11G中,自帶有兩個函數,但在12C中,
oracle不再自帶 wmsys.wm_concat(),如果實際業務中需要到,需要自己創建上。當然,如何創建,會在本文的最后,
會提供兩個版本的 wmsys.wm_concat()和 wmsys.wm_concat()函數沿用過來。 很多人說在12C中, )函數
就已經夠用了,但是在服務過的客戶的應用中,該函數是遠遠不夠使用的,連版本1的 wmsys.wm_concat()函數都不夠用,
不能滿足業務應用的大量拼接業務的使用。

----創建測試表:
--測試表結構:
SQL> set lines 80
SQL> desc suxing.WMCONCAT_TAB
 Name                                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 NAME                                               VARCHAR2(20)
 TEL                                                VARCHAR2(20)
 INSERT_DATE                                        DATE

--測試表記錄數:
SQL> select distinct count(*) from suxing.WMCONCAT_TAB;
  COUNT(*)
----------
    262144

--測試表內容:
SQL> select distinct * from suxing.WMCONCAT_TAB;
NAME                 TEL                  INSERT_DA
-------------------- -------------------- ---------
suxing1              18777104737          27-NOV-17
suxing7              18777104733          27-NOV-17
suxing2              18777104738          27-NOV-17
suxing3              18777104739          27-NOV-17
suxing5              18777104731          27-NOV-17
suxing0              18777104736          27-NOV-17
suxing4              18777104730          27-NOV-17
suxing6              18777104732          27-NOV-17
8 rows selected.

##該表共26w多條記錄,其中是以上8條記錄的重復記錄。三個字段,分別為名字、11位號碼和輸入日期。

----使用不同函數或者不同版本查詢拼接表 LISTAGG( )函數:
SELECT name, LISTAGG(TEL, ',') WITHIN GROUP (ORDER BY TEL) AS pho_lists
FROM   suxing.WMCONCAT_TAB
GROUP BY name;
oracle 12C wmsys.wm_concat()函數
##直接報錯,拼接內容過長,超出該函數的保存長度varchar2(4000 )
oracle 12C wmsys.wm_concat()函數

--使用版本1的 wmsys.wm_concat()函數:
SELECT name,  wm_concat(TEL) AS pho_lists
FROM   suxing.WMCONCAT_TAB
GROUP BY name;
oracle 12C wmsys.wm_concat()函數
##同樣報內部的拼接內容的長度超出了內部類的保存長度pl/sql varchar2 (32767

wmsys.wm_concat()函數
-- wmsys.wm_concat()函數
改版本的函數,拼接的內容是以varchar2(32767 )數據類型的文本形式保存。
一.解鎖wmsys用戶
alter user wmsys identified by "XXXXXX" account unlock;
-- 創建包、包體和函數
以wmsys用戶登錄數據庫,執行下面的命令 CREATE OR REPLACE TYPE WM_CONCAT_IMPL AS OBJECT  
-- AUTHID CURRENT_USER AS OBJECT  
(  
CURR_STR VARCHAR2(32767),   
STATIC FUNCTION ODCIAGGREGATEINITIALIZE(SCTX IN OUT WM_CONCAT_IMPL) RETURN NUMBER,  
MEMBER FUNCTION ODCIAGGREGATEITERATE(SELF IN OUT WM_CONCAT_IMPL,  
P1 IN VARCHAR2) RETURN NUMBER,  
MEMBER FUNCTION ODCIAGGREGATETERMINATE(SELF IN WM_CONCAT_IMPL,  
RETURNVALUE OUT VARCHAR2,  
FLAGS IN NUMBER)  
RETURN NUMBER,  
MEMBER FUNCTION ODCIAGGREGATEMERGE(SELF IN OUT WM_CONCAT_IMPL,  
SCTX2 IN WM_CONCAT_IMPL) RETURN NUMBER  
);  
/  
  
--定義類型body:  
CREATE OR REPLACE TYPE BODY WM_CONCAT_IMPL  
IS  
STATIC FUNCTION ODCIAGGREGATEINITIALIZE(SCTX IN OUT WM_CONCAT_IMPL)  
RETURN NUMBER  
IS  
BEGIN  
SCTX := WM_CONCAT_IMPL(NULL) ;  
RETURN ODCICONST.SUCCESS;  
END;  
MEMBER FUNCTION ODCIAGGREGATEITERATE(SELF IN OUT WM_CONCAT_IMPL,  
P1 IN VARCHAR2)  
RETURN NUMBER  
IS  
BEGIN  
IF(CURR_STR IS NOT NULL) THEN  
CURR_STR := CURR_STR || ',' || P1;  
ELSE  
CURR_STR := P1;  
END IF;  
RETURN ODCICONST.SUCCESS;  
END;  
MEMBER FUNCTION ODCIAGGREGATETERMINATE(SELF IN WM_CONCAT_IMPL,  
RETURNVALUE OUT VARCHAR2,  
FLAGS IN NUMBER)  
RETURN NUMBER  
IS  
BEGIN  
RETURNVALUE := CURR_STR ;  
RETURN ODCICONST.SUCCESS;  
END;  
MEMBER FUNCTION ODCIAGGREGATEMERGE(SELF IN OUT WM_CONCAT_IMPL,  
SCTX2 IN WM_CONCAT_IMPL)  
RETURN NUMBER  
IS  
BEGIN  
IF(SCTX2.CURR_STR IS NOT NULL) THEN  
SELF.CURR_STR := SELF.CURR_STR || ',' || SCTX2.CURR_STR ;  
END IF;  
RETURN ODCICONST.SUCCESS;  
END;  
END;  
/  
--自定義行變列函數:  
CREATE OR REPLACE FUNCTION wm_concat(P1 VARCHAR2)  
RETURN VARCHAR2 AGGREGATE USING WM_CONCAT_IMPL ;  
/  

--創建同義詞并授權:
[sql] view plain copy
create public synonym WM_CONCAT_IMPL for wmsys.WM_CONCAT_IMPL  
/  
create public synonym wm_concat for wmsys.wm_concat  
/  
  
grant execute on WM_CONCAT_IMPL to public  
/  
grant execute on wm_concat to public  
/  


版本2的
該版本的函數,拼接的內容是以clob (4G <span style="white-space:normal;font-family:;" "="">)數據類型的文本形式保存。
alter user wmsys identified by "Test_2017" account unlock;
--創建包、包體和函數:
以wmsys用戶登錄數據庫,執行下面的命令
CREATE OR REPLACE TYPE wm_concat_impl AUTHID CURRENT_USER AS OBJECT
(
  CURR_STR    VARCHAR2(32767),
  CURR_STR_C  CLOB,
  STATIC FUNCTION ODCIAGGREGATEINITIALIZE(SCTX IN OUT WM_CONCAT_IMPL) RETURN NUMBER,
  MEMBER FUNCTION ODCIAGGREGATEITERATE(SELF IN OUT WM_CONCAT_IMPL, P1 VARCHAR2) RETURN NUMBER,
  MEMBER FUNCTION ODCIAGGREGATETERMINATE(SELF WM_CONCAT_IMPL, RETURNVALUE OUT CLOB, FLAGS NUMBER) RETURN NUMBER,
  MEMBER FUNCTION ODCIAGGREGATEMERGE(SELF IN OUT WM_CONCAT_IMPL, SCTX2 WM_CONCAT_IMPL) RETURN NUMBER
);
/ --定義類型body:  
CREATE OR REPLACE TYPE BODY wm_concat_impl IS
  STATIC FUNCTION ODCIAGGREGATEINITIALIZE(SCTX IN OUT WM_CONCAT_IMPL) RETURN NUMBER IS
  BEGIN
    SCTX := WM_CONCAT_IMPL(NULL,NULL) ;
    RETURN ODCICONST.SUCCESS;
  END;
  MEMBER FUNCTION ODCIAGGREGATEITERATE(SELF IN OUT WM_CONCAT_IMPL, P1 VARCHAR2) RETURN NUMBER IS
  BEGIN
    IF (CURR_STR_C IS NULL AND (CURR_STR IS NULL OR LENGTH(CURR_STR)<29950)) THEN
      IF(CURR_STR IS NOT NULL) THEN 
        CURR_STR := CURR_STR || ',' || P1;
      ELSE
        CURR_STR := P1;
      END IF;
    ELSE
      IF (CURR_STR_C IS NULL) THEN
        CURR_STR_C := CURR_STR ;
        CURR_STR := NULL ;
      END IF ;
      CURR_STR_C := CURR_STR_C || ',' || P1;
    END IF ;
    RETURN ODCICONST.SUCCESS;
  END;
  MEMBER FUNCTION ODCIAGGREGATETERMINATE(SELF WM_CONCAT_IMPL, RETURNVALUE OUT CLOB, FLAGS NUMBER) RETURN NUMBER IS
  BEGIN
    IF (CURR_STR IS NOT NULL) THEN
      RETURNVALUE := CURR_STR ;
    ELSE
      RETURNVALUE := CURR_STR_C ;
    END IF ;
    RETURN ODCICONST.SUCCESS;
  END;
  MEMBER FUNCTION ODCIAGGREGATEMERGE(SELF IN OUT WM_CONCAT_IMPL, SCTX2 WM_CONCAT_IMPL) RETURN NUMBER IS
  BEGIN
    IF(SCTX2.CURR_STR IS NOT NULL) THEN 
      SELF.CURR_STR := SELF.CURR_STR || ',' || SCTX2.CURR_STR ;
    END IF;
    RETURN ODCICONST.SUCCESS;
  END;
END;
/

--自定義行變列函數:  
CREATE OR REPLACE FUNCTION wm_concat(P1 VARCHAR2)  
RETURN CLOB AGGREGATE USING WM_CONCAT_IMPL ;  
/  

--創建同義詞并授權:
[sql] view plain copy
create public synonym WM_CONCAT_IMPL for wmsys.WM_CONCAT_IMPL  
/  
create public synonym wm_concat for wmsys.wm_concat  
/  
  
grant execute on WM_CONCAT_IMPL to public  
/  
grant execute on wm_concat to public  
/  

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

五寨县| 凉城县| 九江县| 闸北区| 岳普湖县| 通辽市| 泗阳县| 通河县| 桦南县| 锦州市| 承德市| 格尔木市| 桃园市| 旺苍县| 洮南市| 双城市| 通海县| 历史| 东兰县| 涿州市| 平江县| 玛纳斯县| 瑞昌市| 鹤山市| 德令哈市| 元朗区| 阜康市| 沁水县| 邯郸市| 闸北区| 汾阳市| 阿克| 汽车| 汉沽区| 青河县| 西安市| 崇左市| 宜兴市| 扶风县| 普宁市| 黑河市|