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

本文介绍了在Oracle高版本中遇到'ORA-00904: WM_CONCAT: 标识符无效'错误的原因及解决方案。错误源于WM_CONCAT函数缺失,解决方法是通过sqlplus / as sysdba登录数据库创建该函数。
摘要由CSDN通过智能技术生成

原因:缺少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
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值