• oracle系统包—-dbms_output用法


    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):以数组形式来获取缓冲区的多行信息
    
    需要注意以下几点:
    1set 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
  • 相关阅读:
    JAVA中堆和栈的区别
    怎么回答面试官:你对Spring的理解?
    如何设计一个高可用、高并发秒杀系统
    这应该是把Java内存区域讲的最清楚的一篇文章
    Spring Cloud底层原理解析
    Spring事务管理详解
    选择合适Redis数据结构,减少80%的内存占用
    最强Java并发编程详解:知识点梳理,BAT面试题等
    深入理解HashMap
    Springboot 优雅停止服务的几种方法
  • 原文地址:https://www.cnblogs.com/kakaisgood/p/12761899.html
Copyright © 2020-2023  润新知