下午的时候在 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/977489 和 https://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'; 来设置缓冲区的最大容量。