【案例】ORA-00904:"WM_CONCAT":标识符无效

手工创建该函数
a、以sys用户创建包、包体、函数

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
);

b、创建类型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;

c、创建函数

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

d、创建同义词并授权

create public synonym WM_CONCAT_IMPL for sys.WM_CONCAT_IMPL
create public synonym wm_concat for sys.wm_concat
grant execute on WM_CONCAT_IMPL to public
grant execute on wm_concat to public

然后查看function状态,正常状态。至此问题解决。

总结

1、从网上找资料了解到,11gr2和12C上已经摒弃了wm_concat函数,而应用在程序中确使用了该函数,导致程序出现错误,为了减轻程序员修改程序的工作量,只有通过手工创建个wm_concat函数,来临时解决该问题,但是注意,及时创建了该函数,在使用的过程中,也需要用to_char(wm_concat())方式,才能完全替代之前的应用。

2、也查到了说VMSYS用户下有该函数,但是默认该用户是锁定的,此次问题我也解锁了VMSYS用户,但是并无该function

SQL> alter user WMSYS account unlock;
User altered.
SQL>  select owner,object_name,object_type from dba_objects where owner='WMSYS' and object_type ='FUNCTION';
no rows selected

xxx

select owner,object_name,object_type from dba_objects where  object_type ='FUNCTION' and object_name='WM_CONCAT' like '%CONCAT%'
#查询同义词
select * from dba_synonyms where table_owner = 'SYS' and table_name like '%WM_%'
#删除函数WM_CONCAT
DROP FUNCTION WM_CONCAT
#删除同义词
DROP PUBLIC SYNONYM WM_CONCAT;
#user_objects中的数据为试图数据,如果删除需要 根据类型删除
select * from user_objects order by TIMESTAMP desc
#比如删除函数 WM_CONCAT
DROP FUNCTION WM_CONCAT
#比如删除TYPE WM_CONCAT_IMPL
DROP TYPE WM_CONCAT_IMPL

在Oracle中,USER_OBJECTS是一个数据字典视图,它包含了当前用户所创建的所有对象的信息,包括表、视图、索引、过程、函数、包等。这些信息是从Oracle数据库的内部数据结构中提取出来的,而不是从表或其他对象中提取的。

具体来说,USER_OBJECTS视图中的数据来自于Oracle数据库的内部数据结构,即对象目录(Object Catalog)。对象目录是Oracle数据库的一个内部数据结构,用于存储数据库中所有的对象信息,包括表、视图、索引、过程、函数、包等。当用户在Oracle数据库中创建对象时,对象的信息会被添加到对象目录中。而USER_OBJECTS视图则是从对象目录中提取出当前用户所创建的对象信息,并将其展示给用户。

因此,USER_OBJECTS视图中的数据是来自于Oracle数据库的内部数据结构,即对象目录。

oracle中user_objects试图中数据是哪里来的

oracle中user_objects试图中字段都是什么含义
OBJECT_NAME:对象的名称。
OBJECT_TYPE:对象的类型,例如表、视图、索引、过程、函数等。
OBJECT_ID:对象的唯一标识符。
OBJECT_SERIAL_ID:对象的序列标识符。
OBJECT_INFO:对象的其他信息,例如表的列数、视图的查询语句等。
CREATED:对象创建的时间。
LAST_DDL_TIME:对象最后修改的时间。
TIMESTAMP:对象的版本时间戳。
STATUS:对象的状态,例如正常、不可用等。
这些字段提供了有关当前用户所创建的对象的详细信息,包括名称、类型、唯一标识符、状态等。这些信息可以帮助用户了解和管理他们在Oracle数据库中创建的对象。

posted @ 2023-07-27 11:01  这都没什么  阅读(469)  评论(0编辑  收藏  举报