oracle12版本提示没有wm_concat函数(ORA-00904:“WM_CONCAT“:invalid identifier)
1、使用wm_concat会提示如下错误2、使用如下命令登录到sqlplus中:sqlplus -logon sys/admin1 as sysdba;如下图所示:3、依次执行如下命令:--首先使用dba账号登录oracle数据库--解锁wmsys用户alter user wmsys account unlock;--并为wmsys用户授权,可根据需要授权,不建议授权所有权限grant all p
·
1、使用wm_concat会提示如下错误
2、使用如下命令登录到sqlplus中:
sqlplus -logon sys/admin1 as sysdba;
如下图所示:
3、依次执行如下命令:
--首先使用dba账号登录oracle数据库
--解锁wmsys用户
alter user wmsys account unlock;
--并为wmsys用户授权,可根据需要授权,不建议授权所有权限
grant all privileges to wmsys;
--如果不知道wmsys用户的密码,可以修改其密码
alter user wmsys identified by 123456;
--使用wmsys用户登录数据库
conn wmsys/123456
--在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
);
/
--定义类型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 ;
/
--创建完成,给其创建同义词及授权,以供其他用户能正常使用。
create public synonym WM_CONCAT_IMPL for wmsys.WM_CONCAT_IMPL
/
--如果出现ORA-00955: name is already used by an existing object则执行如下语句
DROP PUBLIC SYNONYM WM_CONCAT_IMPL;
create public synonym wm_concat for wmsys.wm_concat
/
--如果出现ORA-00955: name is already used by an existing object则执行如下语句
DROP PUBLIC SYNONYM wm_concat ;
grant execute on WM_CONCAT_IMPL to public
/
grant execute on wm_concat to public
/
如下图所示:
4、此时在运行即可有WM_CONCAT函数了,如下图所示:
参考:oracle12c取消wm_concat函数,如何重建或使用替代方案?_alicewang99的博客-CSDN博客_wmconcat函数替代

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐
所有评论(0)