调试存储过程时提示ORA-20000: ORU-10027: buffer overflow

 

 

下午的时候在 PL/SQl Developer 10.0.5.1710 上调试壹個存储过程,在调试的时候使用了比较多的 DBMS_OUTPUT.PUT_LINE 作为打印日志的方式,结果没过多久 PLSQL 客户端就开始提示如下错误:ORA-20000: ORU-10027: buffer overflow, limit of 10000 bytes,分析下来是因为函数DBMS_OUTPUT.PUT_LINE()是在循环体中打印结果的,因此,循环执行多少次,这個函数就会执行多少次, 导致缓冲区很快爆满。具体的错误信息如下图所示。

下午的时候在 PL/SQl Developer 10.0.5.1710 上调试壹個存储过程,在调试的时候使用了比较多的 DBMS_OUTPUT.PUT_LINE 作为打印日志的方式,结果没过多久 PLSQL 客户端就开始提示如下错误:ORA-20000: ORU-10027: buffer overflow, limit of 10000 bytes,分析下来是因为函数DBMS_OUTPUT.PUT_LINE()是在循环体中打印结果的,因此,循环执行多少次,这個函数就会执行多少次, 导致缓冲区很快爆满。具体的错误信息如下图所示。

于是果断 Google 了关键字"ORA-20000: ORU-10027: buffer overflow, limit of 10000 bytes",查询结果的前两条就是来自 Oracle Forum 论坛的解决方法。两個链接分别是https://community.oracle.com/message/977489https://community.oracle.com/thread/308557 ,解决的方法也很简单,就是在我们的存储过程的方法体开始的时候增加如下内容:DBMS_OUTPUT.ENABLE(1000000); 使输出的缓冲区的容量达到壹千万個字节,这样就不怕它的容量爆表了。具体的参考代码如下所示:

CREATE OR REPLACE PROCEDURE SAMPLE_PROC
IS
--各种临时变量和游标的定义
	CURSOR CURSOR_SAMPLE IS SELECT ... FROM TABLE_NAME WHERE ...;
BEGIN
	--方法体从这里开始
	DBMS_OUTPUT.ENABLE(1000000);
	FOR I IN CURSOR_SAMPLE	LOOP
		--输出语句样例
		DBMS_OUTPUT.PUT_LINE(...);
	END LOOP;
	--其它内容
END;
/

如果是在命令行下编写存储过程,可以直接使用语句 SET SERVEROUTPUT ON size '1000000'; 来设置缓冲区的最大容量。
当然,如果你需要输出的日志容量真的很大,建议还是不要使用 DBMS_OUTPUT,而是使用 UTL_FILE 输出到指定的日志文件,详细的参考样例见于 http://docs.oracle.com/cd/E11882_01/appdev.112/e40758/u_file.htm#ARPLS70903 ,后者基于 UNIX 系统,不过也可以很容易的照搬到 Windows 平台。

posted @ 2016-07-27 13:39  lclc  阅读(1101)  评论(0编辑  收藏  举报