天堂的狼

更好的生活,来自不懈的努力与拼搏,不要仅仅看中结果,拼搏的过程同样是精彩的!

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: :: 管理 ::

在执行如下sql语句时:

set serveroutput on;
declare
  
--循环所需表
    cursor cur_t_zhcxb is
    
select * from bmrs.t_zhcxb;
begin
   
for rec_t_zhcxb in cur_t_zhcxb loop
    
begin
      dbms_output.put_line(
'insert into t_zhcxb value('''|| rec_t_zhcxb.f_ywbm||' '')');
    
end;
   
end loop;
end;

出现错误:

ERROR 位于第 1 行:
ORA
-20000: ORU-10027: buffer overflow, limit of 2000 bytes
ORA
-06512: 在"SYS.DBMS_OUTPUT", line 34
ORA
-06512: 在"SYS.DBMS_OUTPUT", line 118
ORA
-06512: 在"SYS.DBMS_OUTPUT", line 81
ORA
-06512: 在line 9

在ITPUB论坛上一查发现有人问过类似问题:
http://www.itpub.net/514002.html
解决方法如下:
1、用dbms_output.enable( )设定长度.
DBMS_OUTPUT.ENABLE (buffer_size IN INTEGER DEFAULT 20000); 
(注:该方法按如上设置没成功,直接DBMS_OUTPUT.ENABLE (20000);则成功执行)
2、也可以SET SERVEROUTPUT ON SIZE 5000

其中1方法仅对当次设定有效,删除后仍会提示错误,而2方法是修改配置信息,如果不关闭Sql*plus的该设定仍然存在。

posted on 2006-08-06 13:32  天堂的狼  阅读(1311)  评论(0编辑  收藏  举报