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

时间:2021-07-09 13:26:16
下午的时候在 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()是在循环体中打印结果的,因此,循环执行多少次,这個函数就会执行多少次, 导致缓冲区很快爆满。具体的错误信息如下图所示。

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

于是果断 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 平台。