oracle系统包—-dbms_output用法

dbms_output包主要用于调试pl/sql程序,或者在sql*plus命令中显示信息(displaying message)和报表,譬如我们可以写一个简单的匿名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

1
2
3
4
5
6
7
8
9
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 ;                                                    

执行运行结果:

1
2
ab
hello world!

例子二、put_line

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
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;

执行结果如下:

1
2
3
4
5
a    b
--- -----------------------
0   111111,222222,333333
0   444444,555555,666666
0   777777,888888,999999

注:使用get_line时不能用put_line输出,因为put_line之后会将buffer清空。(当然在serveroutput off的情况下put_line是不影响buffer的)。

例子三:put_lines

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
set  serveroutput on ;
declare
    v_data dbms_output.chararr;                         
    v_numlines number;                                  
begin                                               
    --enable the buffer first.                         
    dbms_output.enable(1000000);                        
                                                      
    dbms_output.put_line( 'line one' );                   
    dbms_output.put_line( 'line two' );                   
    dbms_output.put_line( 'line three' );                
                                                      
    v_numlines := 3;                                   
    dbms_output.get_lines(v_data, v_numlines);  --array, index       
    for  v_counter in  1..v_numlines loop                
        dbms_output.put_line(v_data(v_counter));           
    end  loop;                                          
end ;                                               
/

执行结果如下:

1
2
3
line one
line two
line three

注意数组使用的格式。

 

 

如果您觉得文章有用,也可以给水发个微信小额红包鼓励鼓励!!!

oracle系统包—-dbms_output用法_第1张图片

你可能感兴趣的:(oracle系统包—-dbms_output用法)