Oracle 系统包——dbms_output学习

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u012414590/article/details/68940713

用途

dbms_output包主要用于调试pl/sql程序,或者在sqlplus命令中显示信息,譬如我们可以写一个简单的匿名pl/sql程序块,而该块出于某种目的使用dbms_output包来显示一些信息

知识点

1.enable:在serveroutput on的情况下,用来使dbms_output生效(默认即打开)
2.disable:在serveroutput on的情况下,用来使dbms_output失效
3.put:将内容写到内存,等到put_line时一起输出
4.put_line:输出字符
5.new_line:作为一行的结束,可以理解为写入buffer时的换行符
6.get_line(value, index):获取缓冲区的单行信息
7.get_lines(array, index):以数组形式来获取缓冲区的多行信息

注意:
1.set serveroutput on:如果要在sqlplus中看到dbms_output的输出,则必须设置该参数值为on
2.每行能容纳的最大值是32767bytes
3.buffer的默认值是20000bytes,可设置的最小值为2000bytes,最大值为1000000bytes

put和new_line

set serveroutput on;
begin
   dbms_output.put('a'); --写入buffer但不输出
   dbms_output.put('b'); --写入buffer但不输出
   dbms_output.new_line; --回车(换行),输出                              
   dbms_output.put_line('hello world!'); --输出并换行 
   dbms_output.put('d'); --写入buffer但不输出 
end; 

执行结果:

ab
hello world!

put_line

set serveroutput off;
create table t(a int, b int, c int);
insert into t values(111111,222222,333333);
insert into t values(444444,555555,666666);
insert into t values(777777,888888,999999);
commit;

create table tt(a int,b varchar2(100));

declare
   msg varchar2(120);                               
   cursor t_cur is select * from t order by a;      
   v_line varchar2(100);                            
   v_status integer := 0;                           
begin                                           
   dbms_output.enable;                              
   for i in t_cur loop                              
       msg := i.a || ',' || i.b || ',' || i.c;          
       dbms_output.put_line(msg); --put                   
   end loop;                                       

   dbms_output.get_line(v_line, v_status); --get          
   while v_status = 0 loop                         
       insert into tt values(v_status, v_line);        
       dbms_output.get_line(v_line, v_status);          
   end loop;                                       
end;

select * from tt;

执行结果:

a    b
--- ----------------------- 
0   111111,222222,333333
0   444444,555555,666666
0   777777,888888,999999

猜你喜欢

转载自blog.csdn.net/u012414590/article/details/68940713