en_concat函式編譯失敗處理

老w愛db發表於2022-10-08

近日,某專案組反饋en_concat函式編譯報錯

處理方法:

一、建立type:

CREATE OR REPLACE TYPE "EN_CONCAT_IM" 

  AUTHID CURRENT_USER AS OBJECT 

  ( 

    CURR_STR VARCHAR2(32767), 

    STATIC FUNCTION ODCIAGGREGATEINITIALIZE(SCTX IN OUT en_concat_im) RETURN NUMBER, 

    MEMBER FUNCTION ODCIAGGREGATEITERATE(SELF IN OUT en_concat_im, 

          P1 IN VARCHAR2) RETURN NUMBER, 

    MEMBER FUNCTION ODCIAGGREGATETERMINATE(SELF IN en_concat_im, 

                RETURNVALUE OUT VARCHAR2, 

                FLAGS IN NUMBER) 

          RETURN NUMBER, 

    MEMBER FUNCTION ODCIAGGREGATEMERGE(SELF IN OUT en_concat_im, 

         SCTX2 IN  en_concat_im) RETURN NUMBER 

  ); 

二、建立type body


CREATE OR REPLACE TYPE BODY "EN_CONCAT_IM" 

  IS 

    STATIC FUNCTION ODCIAGGREGATEINITIALIZE(SCTX IN OUT en_concat_im) 

    RETURN NUMBER 

    IS 

    BEGIN 

     SCTX := en_concat_im(NULL) ; 

     RETURN ODCICONST.SUCCESS; 

    END; 

    MEMBER FUNCTION ODCIAGGREGATEITERATE(SELF IN OUT en_concat_im, 

           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 en_concat_im, 

                RETURNVALUE OUT VARCHAR2, 

                FLAGS IN NUMBER) 

     RETURN NUMBER 

    IS 

    BEGIN 

     RETURNVALUE := CURR_STR ; 

     RETURN ODCICONST.SUCCESS; 

    END; 

    MEMBER FUNCTION ODCIAGGREGATEMERGE(SELF IN OUT en_concat_im, 

            SCTX2 IN en_concat_im) 

    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; 


三、重新編譯en_concat函式


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/70021989/viewspace-2917267/,如需轉載,請註明出處,否則將追究法律責任。

相關文章