解决Oracle高版本 ORA-00904: “WM_CONCAT“: 标识符无效

原因:缺少WM_CONCAT函数

解决方案:创接一个

使用sqlplus / as sysdba登录数据库

-- 创建wm_concat函数
-- 首先使用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

你可能感兴趣的:(oracle,数据库,dba)