学習--dbms_output Oracleシステムパッケージ

免責事項:この記事はブロガーオリジナル記事ですが、許可ブロガーなく再生してはなりません。https://blog.csdn.net/u012414590/article/details/68940713

使用

DBMS_OUTPUTパッケージが主に使用されているデバッグPL / SQLプログラムに、またはsqlplusコマンドで情報を表示するには、例えば、私たちはメッセージを表示するには、DBMS_OUTPUTパッケージの簡単な無名PL / SQLブロック、およびいくつかの目的のためにブロックを書き込むことができます

知識ポイント

1.enable:上SERVEROUTPUTの場合は、有効になりDBMS_OUTPUT作るために使用される(デフォルトが開きます)
2.disable:上SERVEROUTPUTの場合は、障害DBMS_OUTPUT作るために使用される
3.put:PUT_LINEまで、メモリに内容を書き込むこと出力一緒
4.put_line:文字出力
5.new_line:行の終わりとして、改行が理解されよう書き込みバッファ
6.get_line(値、指数):シングルラインバッファ情報取得
7.get_lines(配列インデックス) :マルチライン・メッセージの配列としてバッファを取得します

注意:
上の1.setのSERVEROUTPUT:あなたはSQLPLUSでDBMS_OUTPUTの出力を確認したい場合は、パラメータ値に設定する必要がありますがあり
、各列の最大値が2を収容することができ32767bytesされる
デフォルト3.bufferが20000bytesで、設定可能最小値は2000bytes、最大値1000000bytesあります

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