oracle concat()函数_Oracle19C升级WM_CONCAT函数失效

1.1 问题背景

最近项目Oracle数据库升级由11g升到19C,在验证过程中发现wm_concat函数竟然失效了。

经过网上查询资料发现,wm_concat函数是oracle的非公开函数,在新版的oracle中不支持该函数。

3ceebbefd75ff2e85a938b70c66f4cf9.png

1.2 解决方案

因该函数在代码中使用次数过多,在不改动代码前提下,选择重新创建该函数。建议后续在开发过程中不建议再使用该函数。

1.3 实施步骤

--首先使用dba账号登录oracle数据库(使用oracle / root用户执行)

sqlplus / as sysdba

95a3571568560696804a9afab8023a74.png

--解锁wmsys用户

alter user wmsys account unlock;

471578526f4586c83d8465deb461cc3e.png

--并为wmsys用户授权,可根据需要授权,不建议授权所有权限

grant all privileges to wmsys;

c9308beed93a25aa8027d17348286686.png

--如果不知道wmsys用户的密码,可以修改其密码

alter user wmsys identified by Pro_ut#19;

1ad296826e7356528d49e3427af2c543.png

--使用wmsys用户登录数据库

conn wmsys/Pro_ut#19

36943caf6edc0c680a9afb8b0963ee75.png

--在wmsys下创建可用的wm_concat函数,直接执行以下语句

--定义类型

CREATE OR REPLACE TYPE WM_CONCAT_IMPL 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);/

0cf3f254b1570d7ad1fcb425dafafab5.png

--定义类型body:

CREATE OR REPLACE TYPE BODY WM_CONCAT_IMPLISSTATIC FUNCTION ODCIAGGREGATEINITIALIZE(SCTX IN OUT WM_CONCAT_IMPL)RETURN NUMBERISBEGINSCTX := WM_CONCAT_IMPL(NULL) ;RETURN ODCICONST.SUCCESS;END;MEMBER FUNCTION ODCIAGGREGATEITERATE(SELF IN OUT WM_CONCAT_IMPL,P1 IN VARCHAR2)RETURN NUMBERISBEGINIF(CURR_STR IS NOT NULL) THENCURR_STR := CURR_STR || ',' || P1;ELSECURR_STR := P1;END IF;RETURN ODCICONST.SUCCESS;END;MEMBER FUNCTION ODCIAGGREGATETERMINATE(SELF IN WM_CONCAT_IMPL,RETURNVALUE OUT VARCHAR2,FLAGS IN NUMBER)RETURN NUMBERISBEGINRETURNVALUE := CURR_STR ;RETURN ODCICONST.SUCCESS;END;MEMBER FUNCTION ODCIAGGREGATEMERGE(SELF IN OUT WM_CONCAT_IMPL,SCTX2 IN WM_CONCAT_IMPL)RETURN NUMBERISBEGINIF(SCTX2.CURR_STR IS NOT NULL) THENSELF.CURR_STR := SELF.CURR_STR || ',' || SCTX2.CURR_STR ;END IF;RETURN ODCICONST.SUCCESS;END;END;/

9401be75b683d2a68752ad0ee6add638.png

--自定义行变列函数:

CREATE OR REPLACE FUNCTION wm_concat(P1 VARCHAR2)RETURN VARCHAR2 AGGREGATE USING WM_CONCAT_IMPL ;/

9dc6a6fd95e9a83ff08d7b67d56d969a.png

--创建完成,给其创建同义词及授权,以供其他用户能正常使用。

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/

8e61825a29d6463d2d8bb391cbde5202.png

1.4 方案验证

wm_concat函数可正常使用

ea56492d76afedec073a9f2516fce615.png

end

ea72d6101a4a7cc0ab01a401659888f1.png


版权声明:本文为weixin_34898320原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。