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):以数组形式来获取缓冲区的多行信息

需要注意以下几点:
1、set 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

注意数组使用的格式。

时间: 2024-10-15 18:02:36

oracle系统包—-dbms_output用法的相关文章

oracle系统包——dbms_random用法及order by 小结(转)

dbms_random是一个可以生成随机数值或者字符串的程序包. 这个包有initialize().seed().terminate().value().normal().random().string()等几个函数,但value()是最常用的,下面依次介绍各个函数的详细用法: 1.dbms_random.value方法 第一种:FUNCTION value RETURN NUMBER; 说明: 这种用法没有参数,会返回一个具有38位精度的数值,范围从0.0到1.0,但不包括1.0. 示例: S

oracle系统包——dbms job用法(oracle定时任务)

用于安排和管理作业队列,通过使用作业,可以使ORACLE数据库定期执行特定的任务. 一.dbms_job涉及到的知识点1.创建job:variable jobno number;dbms_job.submit(:jobno, —-job号                  'your_procedure;',—-执行的存储过程, ';'不能省略                 next_date, —-下次执行时间                  'interval' —-每次间隔时间,int

ORACLE系统包DBMS_REDEFINITION实现表的在线重定义

ORACLE自带的DBMS_REDEFINITION包功能非常强大,可以用于降低高水位线,回收碎片空间,对表做在线重定义(添加或删除字段,改变字段类型,普通表重定义表为分区表,分区表重定义表为普通表等等) 另外,它有一个非常强大的功能,"在线"二字体现得淋漓尽致,但是也并不是完全的在线,因为在完成重定义前的最后一下,会持会表级排他锁,但这个锁定时间是可控的. 如果你也曾为delete无法降低高水位线而烦恼或者由于历史表太大导致维护困难,我相信这篇文章将对你有很大的感触,因此相信绝大朋友

Oracle-常用系统数据字典表、系统包功能分类

近期因为用到了一些关于系统的一些信息,索性搜集了一点关于Oracle数据库系统的一些系统表.功能等,方便日后查看.日后待补充. 原文地址:https://blog.csdn.net/demonson/article/details/53189513: [查看用户下属的一些表及其他结构信息] 查看表:user_tables.all_tables.dba_tables查看表字段:user_tab_columns.all_ tab_columns.dba_tab_columns查看表注释:user_

Oracle to_date()函数的用法《转载》

to_date()是Oracle数据库函数的代表函数之一,下文对Oracle to_date()函数的几种用法作了详细的介绍说明, 原文地址:http://database.51cto.com/art/201010/231193.htm 在Oracle数据库中,Oracle to_date()函数是我们经常使用的函数,下面就为您详细介绍Oracle to_date()函数的用法,希望可以对您有所启迪. to_date()与24小时制表示法及mm分钟的显示: 一.在使用Oracle的to_date

Oracle中Cursor的用法

关键字 ?概念 ?类型 ?异常处理 一 概念 游标是SQL的一个内存工作区,由系统或用户以变量的形式定义.游标的作用就是用于临时存储从数据库中提取的数据块.在某些情况下,需要把数据从存放在磁 盘的表中调到计算机内存中进行处理,最后将处理结果显示出来或最终写回数据库.这样数据处理的速度才会提高,否则频繁的磁盘数据交换会降低效率. 二  类型   Cursor类型包含三种: 隐式Cursor,显式Cursor和Ref Cursor(动态Cursor). 1. 隐式Cursor: 1).对于Selec

oracle管道函数的用法

oracle管道函数是一类特殊的函数,oracle管道函数返回值类型必须为集合,下面将介绍oracle管道函数的语法. 在普通的函数中,使用dbms_output输出的信息,需要在服务器执行完整个函数后一次性的返回给客户端.如果需要在客户端实时的输出函数执行过程中的一些信息,在oracle9i以后可以使用管道函数(pipeline function). 关键字PIPELINED表明这是一个oracle管道函数,oracle管道函数的返回值类型必须为集合,在函数中,PIPE ROW语句被用来返回该

Oracle to_date()函数的用法介绍

to_date()是Oracle数据库函数的代表函数之一,下文对Oracle to_date()函数的几种用法作了详细的介绍说明,需要的朋友可以参考下 在Oracle数据库中,Oracle to_date()函数是我们经常使用的函数,下面就为您详细介绍Oracle to_date()函数的用法,希望可以对您有所启迪. to_date()与24小时制表示法及mm分钟的显示: 一.在使用Oracle的to_date函数来做日期转换时,很多Java程序员也许会直接的采用"yyyy-MM-dd HH:m

Oracle to_date()函数的用法

Oracle to_date()函数的用法 to_date()是Oracle数据库函数的代表函数之一,下文对Oracle to_date()函数的几种用法作了详细的介绍说明,供您参考学习. 在Oracle数据库中,Oracle to_date()函数是我们经常使用的函数,下面就为您详细介绍Oracle to_date()函数的用法,希望可以对您有所启迪. to_date()与24小时制表示法及mm分钟的显示: 一.在使用Oracle的to_date函数来做日期转换时,很多Java程序员也许会直接