Oracle 系统包 —— dbms_output 学习

用途

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.每行能容纳的最大值是 32767 bytes
3.buffer的默认值是 20000 bytes,可设置的最小值为 2000 bytes,最大值为 1000000 bytes

put 和 new_line

1
2
3
4
5
6
7
8
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
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
查看评论