Переполнение буфера в размере dbms_output - PullRequest
5 голосов
/ 08 ноября 2011

Я пытался установить неограниченный размер dbms_output внутри хранимой процедуры.

Но это дало мне ошибки компиляции. Поэтому я попытался в подсказке SQL * Plus ниже. Но все равно я получаю ошибку переполнения буфера. Как я могу преодолеть это?

 set serveroutput on size unlimited;
 exec service_update;


ORA-20000: ORU-10027: buffer overflow, limit of 30000 bytes
ORA-06512: at "SYS.DBMS_OUTPUT", line 32
ORA-06512: at "SYS.DBMS_OUTPUT", line 97
ORA-06512: at "SYS.DBMS_OUTPUT", line 112
ORA-06512: at "ARBOR.SERVICE_UPDATE", line 27
ORA-06512: at line 1

Ответы [ 2 ]

12 голосов
/ 08 ноября 2011

В процедуре service_update, случайно, есть вызов

dbms_output.enable(30000); 

Это может переопределить первый установленный вами предел.

4 голосов
/ 03 апреля 2014

В Oracle 10gR2 вы также можете использовать неограниченный буфер (https://forums.oracle.com/forums/thread.jspa?threadID=361639):

dbms_output.enable(null);
...