oracle系统包—-dbms_output用法
来源:互联网 发布:txt转mobi for mac 编辑:程序博客网 时间:2024/05/16 00:31
http://www.cnblogs.com/linjiqin/p/3152647.html
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
set serveroutputon;
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 serveroutputoff;
create table t(aint, b int, c int);
insert into tvalues(111111,222222,333333);
insert into tvalues(444444,555555,666666);
insert into tvalues(777777,888888,999999);
commit;
create table tt(aint,b varchar2(100));
declare
msg varchar2(120);
cursor t_curis select *from torder by a;
v_line varchar2(100);
v_statusinteger := 0;
begin
dbms_output.enable;
for iin 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 ttvalues(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
注:使用get_line时不能用put_line输出,因为put_line之后会将buffer清空。
(当然在serveroutput off的情况下put_line是不影响buffer的)。
*****************************************************************************************
例子三:put_lines
set serveroutputon;
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_counterin 1..v_numlines loop
dbms_output.put_line(v_data(v_counter));
end loop;
end;
/
执行结果如下:
line one
line two
line three
注意数组使用的格式。
*****************************************************************************************
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
set serveroutputon;
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 serveroutputoff;
create table t(aint, b int, c int);
insert into tvalues(111111,222222,333333);
insert into tvalues(444444,555555,666666);
insert into tvalues(777777,888888,999999);
commit;
create table tt(aint,b varchar2(100));
declare
msg varchar2(120);
cursor t_curis select *from torder by a;
v_line varchar2(100);
v_statusinteger := 0;
begin
dbms_output.enable;
for iin 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 ttvalues(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
注:使用get_line时不能用put_line输出,因为put_line之后会将buffer清空。
(当然在serveroutput off的情况下put_line是不影响buffer的)。
*****************************************************************************************
例子三:put_lines
set serveroutputon;
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_counterin 1..v_numlines loop
dbms_output.put_line(v_data(v_counter));
end loop;
end;
/
执行结果如下:
line one
line two
line three
注意数组使用的格式。
*****************************************************************************************
0 0
- oracle系统包—-dbms_output用法
- oracle系统包—-dbms_output用法
- 【转】oracle系统包—-dbms_output用法
- oracle系统包—-dbms_output用法
- oracle系统包—-dbms_output用法
- oracle系统包--dbms_output的用法
- oracle系统包DBMS_OUTPUT
- Oracle 系统包——dbms_output学习
- IT忍者神龟之oracle系统包 dbms_output用法
- dbms_output 系统包
- Oracle DBMS_OUTPUT包完全参考手册
- 【Oracle】Oracle中DBMS_OUTPUT包的使用
- Oracle DBMS_OUTPUT 用法例子(转载)
- oracle系统包——DBMS_PIPE用法
- oracle系统包——dbms_alert用法
- oracle系统包——dbms_transaction用法
- oracle系统包——dbms_random用法
- oracle系统包——dbms_alert用法
- 递归&迭代
- 执行命令
- Android Context 是什么?
- [Android] 浅析总结 AS 中 Gradle 配置运行
- JDBC 事务处理
- oracle系统包—-dbms_output用法
- Apache SAMOA on Flink试用
- 硬件电路设计入门奉献系列(一)
- 图遍历
- UVA11988 链表非指针
- 冒泡排序
- Android 实时视频编码—H.264硬编码
- IAR for STM8 为何可以不配置时钟?
- HLS学习(一)HLS介绍