首页 > 数据库 > Oracle > 正文

oracle系统包—-dbms_output用法

2024-08-29 13:54:32
字体:
来源:转载
供稿:网友

http://www.cnblogs.com/linjiqin/p/3152647.htmldbms_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的输出,则必须设置该参数值为on2、每行能容纳的最大值是32767bytes3、buffer的默认值是20000bytes,可设置的最小值为2000bytes,最大值为1000000bytes*****************************************************************************************例子一、put和new_lineset 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;  执行运行结果:abhello world!*****************************************************************************************例子二、put_lineset 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,3333330   444444,555555,6666660   777777,888888,999999注:使用get_line时不能用put_line输出,因为put_line之后会将buffer清空。(当然在serveroutput off的情况下put_line是不影响buffer的)。*****************************************************************************************例子三:put_linesset 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 oneline twoline three注意数组使用的格式。*****************************************************************************************


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表