Oracle 9.2.0.1版本函数编译的一个BUG

王朝oracle·作者佚名  2008-06-01
窄屏简体版  字體: |||超大  

环境:

OS:Windows 2003 Server

ORACLE9.2.0.1

现象:在进行PL/SQL 函数编译时加上DEBUG会出现死机,详细描述如下:

下面是一个函数:

SQL> create or replace function A2(arg_bh User_Tables.table_name%type)

2 return number is

3 Result VARCHAR2(50);

4 begin

5 select arg_bh || rpad(arg_bh, 46) || '(测试)' into Result from dual;

6 end A2;

7 /

Function created

SQL> alter function a2 compile;

Function altered

SQL> alter function a2 compile debug;

然后就出现了数据库死机现象,CPU100%

会话处理等待状态,等待事件为null event

锁住了以下系统表

SYS ERROR$

SYS PROCEDUREINFO$

SYS ARGUMENT$

SYS PROCEDUREC$

SYS PROCEDUREJAVA$

SYS VTABLE$

SYS PROCEDURE$

SYS IDL_UB1$

SYS IDL_CHAR$

SYS IDL_UB2$

SYS IDL_SB4$

使用KILL不能杀掉进程,进程一直处于killed状态,通过orakill命令才可以KILL进程

做过一些测试,发现主要问题是以下代码片段引起的:

arg_bh User_Tables.table_name%type

arg_bh || rpad(arg_bh, 46) || '(测试)'

在数据库 9.2.0.7中同样的代码编译正常,说明这是9.2.0.1的BUG,具体不知道在什么版本中修复了,所以建议大家在开发时最好升级到高一些的版本。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航