Home >Database >Mysql Tutorial >用Oracle自带脚本 重建WMSYS用户的WMSYS.WM_CONCAT函数

用Oracle自带脚本 重建WMSYS用户的WMSYS.WM_CONCAT函数

WBOY
WBOYOriginal
2016-06-07 17:24:362283browse

在将Oracle8i升级到Oracle10g后,应用程序的部分视图编译不能通过。提示错误如下:ORA-00904: wm_concat:invalid identifier

在将Oracle8i升级到Oracle10g后,应用程序的部分视图编译不能通过。提示错误如下:

ORA-00904: "wm_concat":invalid identifier

查询DBA_OBJECTS视图,也未发现wm_concat的相关信息。

正常情况下查询,,

SQL> SELECT * FROM DBA_OBJECTS WHERE OBJECT_NAME LIKE 'WM_CONCAT%';

应如下所示:

 

但在客户系统中,该SQL语句返回了0行。

可发现报错的原因,是因为系统从8i升级到10g时,没创建WMSYS用户及相关函数。

WM_CONCAT函数在某些场合,还是挺有用的。可以实现将多行数据合并到一行里,以逗号分隔。

一旦该函数异常,应用程序就可能报错。

解决办法:

简单来说,用SQLPLUS执行下一下几个脚本就可以了。

SQL>@$ORACLE_HOME\RDBMS\ADMIN\owmctab.plb;
SQL>@$ORACLE_HOME\RDBMS\ADMIN\owmaggrs.plb
SQL>@$ORACLE_HOME\RDBMS\ADMIN\owmaggrb.plb

下面我们来做测试,先从系统上删除用户WMSYS。

SQL> select account_status,wmsys.wm_concat(username) from dba_users group by account_status;
select account_status,wmsys.wm_concat(username) from dba_users group by account_status;
                      *
第 1 行出现错误:
ORA-00904: "WMSYS"."WM_CONCAT": 标识符无效


SQL> @D:\oracle\product\10.2.0\db_1\RDBMS\ADMIN\owmctab.plb

函数已创建。


授权成功。


PL/SQL 过程已成功完成。


授权成功。


过程已创建。


类型已创建。


类型已创建。


PL/SQL 过程已成功完成。


表已创建。


索引已创建。


索引已创建。


表已创建。


序列已创建。


表已创建。


序列已创建。


表已创建。


已创建 1 行。


提交完成。


序列已创建。


表已创建。


表已创建。


索引已创建。


表已创建。


已创建 1 行。


类型已创建。


PL/SQL 过程已成功完成。


类型已创建。


PL/SQL 过程已成功完成。


表已创建。


序列已创建。


表已创建。


已创建 1 行。


已创建 1 行。


已创建 1 行。


已创建 1 行。


已创建 1 行。


已创建 1 行。


已创建 1 行。


提交完成。


表已创建。


表已创建。


类型已创建。


表已创建。


PL/SQL 过程已成功完成。


表已创建。


序列已创建。


序列已创建。


序列已创建。


表已创建。


表已创建。


序列已创建。


表已创建。

INSERT INTO sys.exppkgact$ VALUES ('LT_EXPORT_PKG','SYS',1,1000)
*
第 1 行出现错误:
ORA-00001: 违反唯一约束条件 (SYS.I_ACTPACKAGE)


INSERT INTO sys.exppkgact$ VALUES ('LT_EXPORT_PKG','SYS',2,1000)
*
第 1 行出现错误:
ORA-00001: 违反唯一约束条件 (SYS.I_ACTPACKAGE)

 

提交完成。


表已创建。


表已创建。


索引已创建。


已创建 1 行。


提交完成。


索引已创建。


表已创建。


表已创建。


已更新 1 行。


提交完成。


表已更改。


PL/SQL 过程已成功完成。


表已更改。


表已更改。


表已更改。


已更新 1 行。


提交完成。


索引已创建。


索引已创建。


索引已创建。


索引已创建。


索引已创建。


索引已创建。


索引已创建。


索引已创建。


索引已创建。


PL/SQL 过程已成功完成。


索引已创建。


索引已创建。


索引已创建。


已删除0行。


已创建 1 行。


提交完成。


表已创建。


索引已创建。


已更新 1 行。


提交完成。


索引已删除。


索引已创建。


表已创建。


表已更改。


表已更改。


表已创建。


序列已创建。


索引已删除。


索引已创建。


表已更改。


已更新 1 行。


提交完成。

SQL> @D:\oracle\product\10.2.0\db_1\RDBMS\ADMIN\owmaggrs.plb

类型已创建。


PL/SQL 过程已成功完成。


函数已创建。


PL/SQL 过程已成功完成。


同义词已创建。

SQL> @D:\oracle\product\10.2.0\db_1\RDBMS\ADMIN\owmaggrb.plb

类型主体已创建。

SQL> select account_status,wmsys.wm_concat(username) from dba_users
  2  group by account_status;

ACCOUNT_STATUS                                                                 
--------------------------------                                               
WMSYS.WM_CONCAT(USERNAME)                                                     
--------------------------------------------------------------------------------
EXPIRED & LOCKED                                                               
SCOTT,TSMSYS,MDDATA,DIP,ORDSYS,DMSYS,CTXSYS,XDB,SI_INFORMTN_SCHEMA,OUTLN,OLAPSYS
,ORDPLUGINS,ANONYMOUS,WMSYS,EXFSYS,MDSYS                                       
                                                                               
OPEN                                                                           
AAA,WSFX,SYSTEM,SYS,MGMT_VIEW,SYSMAN,DBSNMP,BAS,TEST,ADMIN,TESTI               

以上创建步骤,可恢复WMSYS用户的WM_CONCAT函数。

网上有手工创建该函数的脚本,仅将Oracle提供的部分脚本,解密出来执行,操作比较麻烦。

我们更推荐使用本文的方法。就像山寨机与品牌机的差别,你懂的!

linux

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn