Oracle数据库PL/SQL过程调试的输出方法

2008-8-25  选择字号:  | |
打印本文章

1.最基本的DBMS_OUTPUT.PUT_LINE()方法

随便在什么地方,只要是BEGIN和END之间,就可以使用DBMS_OUTPUT.PUT_LINE(output);

然而这会有一个问题,就是使用该函数一次最多只可以显示255个字符,否则缓冲区会溢出。

此外,函数DBMS_OUTPUT.ENABLE(20000)这种函数,仅仅是设置整个过程的全部输出缓冲区大小,而非DBMS_OUTPUT.PUT_LINE()的缓冲区大小。

对于超过255个字符的变量,使用DBMS_OUTPUT.PUT_LINE()方法是没有效的。据说在Oracle10中,解除了这个限制,可以输出任意大小的字符串。

declare

output varchar2(200);

begin

output:=’’...’’; //赋值

DBMS_OUTPUT.PUT_LINE(output);

end;

如果以上执行结果成功但没有显示请执行 set serveroutput on; 然后就可以了;

2.使用表的方法

首先建立一张表,然后在PL/SQL中将要输出的内容插到表中。然后再从表中查看内容。对于这种方法一次可以输出几千个字符。

(1) create table my_output{

id number(4),

txt varchar2(4000)

);

(2) declare

output varchar2(4000);

strSql varchar2(4500);

count number(4):=0;

begin

strSql:=’’delete * from my_output’’;

execute IMMEDIATE strSql;

output:=’’...’’; //赋值

count:=count+1;

strSql:=’’insert into my_output value (count,’’’’’’||output||’’’’’’)’’;

--’’’’在单引号中相当于字符’’

execute IMMEDIATE strSql;

end;

3.使用输出文件的方法

如果变量非常大,以致连使用表都没有办法插入时,只有使用文件方式了。

(1) create or replace directory TMP as ’’d:\testtmp’’;

--建立一个文件夹路径

(2) declare

file_handle UTL_FILE.FILE_TYPE;

output varchar2(30000);

begin

output:="....";

file_handle := UTL_FILE.FOPEN(’’TMP’’, ’’output.txt’’, ’’w’’,[1-32767]);

--四个参数:目录,文件名,打开方式,最大行数(默认为2000)

UTL_FILE.PUT_LINE(file_handle, output);

UTL_FILE.FCLOSE(file_handle);

exception

WHEN utl_file.invalid_path THEN

raise_application_error(-20000, ’’ERROR: Invalid path for file or path not in INIT.ORA.’’);

end;

原文出处:http://tech.ccidnet.com/art/1105/20080815/1545087_1.html
来源:赛迪网    作者:天力    
相关的新闻
本文只是一个例子,大家可以把它封装成一个通用函数进行实用。大家在试的时候将里面相应的其它进制的数值换成自己的数据就可以了……
PL/SQL是由构造程序、统计数据、模块性以及异常管理等建模观念发展而来的。它扩展了ADA程序语言。ADA扩展了Pascal程序语言,包括配置、比较运算符以及单引字符串分隔符。
随便在什么地方,只要是BEGIN和END之间,就可以使用DBMS_OUTPUT.PUT_LINE(output); 而这有个问题,就是使用该函数最多只可以显示255个字符,否则缓冲区会溢出。
个人认为ORACLE实在不适合来讨论算法,所以只挑了一个比较简单的算法进行计算,多项式为:PI=2+1/3*(2+2/5*(2+3/7*(2+…(2+N/(2N+1))…))),上一篇之所以给出……
经常可以碰到Oracle的内部错误ORA-600和ORA-7445,这个PL/SQL的内部错误还是第一次碰到。在11g中建立10.1或10.2基表的物化视图,就会引发这个错误。
本专题主要介绍SQL Server 2008的新增特征:SQL Server 2008中的T-SQL基本对象和操作、T-SQL的函数类型和数据类型以及新的安全特性等等。
本篇文章主要介绍SQL Server数据存储的物理对象和原理,包括SQL Server 2005和2008里的物理数据存储、SQL Server 2008数据类型(即Datetime、字符串、自定义及等)、在SQL Server数据库中加强数据的完整性……
本文为SQL Server 2008初学者指南,主要介绍SQL Server2008 T-SQL支持的基本元素和基本操作。
最新更新
专家答疑
技巧
Phillip Bracken
我怎样在Oracle中增加SGA_MAX_SIZE?在计算机启动的时候出现了以下错误:"ORA-03113: end-of-file on communication channel"。请您告诉我增加SGA的一些步骤。
Rudy Limeback
我想用REPLACE语句替换AddressLine1域里面的数据,也就是想删除逗号、周期、连字符,并将 '3 South '替换成'3 S ' 然后……
Brian Peasland
设计备份方案时主要考虑哪些因素?什么是RTO、MTBF和MTTR?我不敢100%肯定RTO,但是我觉得就是Return to Operation的意思。换句话说就是将系统返回到正常操作时间……