Oracle PL/SQL进阶编程(第六弹:使用系统包:DBMS_OUTPUT)

本文介绍了Oracle中的DBMS_OUTPUT系统包,主要用于在PL/SQL程序中调试输出信息。通过启用和禁用包,使用PUT_LINE和GET_LINE等过程向缓冲区写入和提取内容。DBMS_OUTPUT提供了方便的方式来查看存储过程和触发器中的中间结果,但不适合报表输出。在SQL*Plus中,可以通过设置和检查缓冲区内容来显示输出。
摘要由CSDN通过智能技术生成

该包使得我们可以从存储过程、包或触发器中发送信息。

Oracle推荐在调试PL/SQL程序时使用该包,不建议使用它来做报表输出或其他的格式化应用。

启用或禁用DBMS_OUTPUT

默认情况下,Oracle并没有启用DBMS_OUTPUT包,也就是说,直接使用DBMS_OUTPUT.PUT_LINEGET_LINE来输出或获取消息,是看不到任何输出的。要先使用DBMS_OUTPUT.ENABLE来启用包的功能。
DBMS_OUTPUT.ENABLE(buffer_size IN INTEGER DEFAULT 20000);
buffer_size用来指定缓冲区,缓冲区的最大尺寸为1000000字节 ,最小为2000字节,默认为20000字节。

SQL*Plus有一个SET SERVEROUTPUT ON语句,来启用DBMS_OUTPUT包,如果执行了该语句,则没有必要使用DBMS_OUTPUT.ENABLE,因为SET SERVEROUTPUT ON会自动调用该语句。

禁用DBMS_OUTPUT只需要调用DBMS_OUTPUT.DISABLE即可,它同时会清除缓冲区中所有的数据。当执行SET SERVEROUTPUT OFF时,SQL*Plus也会调用DBMS_OUTPUT.DISABLE过程。

向缓冲区中提取与写入内容

必须要理解的是,DBMS_OUTPUT并不是直接将信息输出到屏幕,而是将数据写入到了一个缓冲区中,然后再次将这些输出读回。当在SQL*Plus中使用SET SERVEROUTPUT ON命令时,实际上是让SQL*Plus在每条DBMS_OUTPUT之后检查缓冲区中的内容,然后在屏幕上进行显示。

可以使用如下几个过程来向缓冲区中输入消息:
- PUT:将信息写入缓冲区,不包含换行符。
- PUT_LINE:将完整的行信息写入缓冲区&

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值