调试存储过程时提示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()是在循环体中打印结果的,所以,循环执行多少次,这個函数就会执行多少次,致使缓冲区很快爆满。具体的错误信息以下图所示。 sql

因而果断 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); 使输出的缓冲区的容量达到壹千万個字节,这样就不怕它的容量爆表了。具体的参考代码以下所示: oracle

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 平台。
相关文章
相关标签/搜索