WEB开发网
开发学院数据库Oracle 使用OLE DB和ADO调用返回记录集的Oracle存储过程 阅读

使用OLE DB和ADO调用返回记录集的Oracle存储过程

 2007-05-13 12:32:00 来源:WEB开发网   
核心提示: OPEN p_cursor FORSELECT deptno FROM emp WHERE empno = inempno;RETURN (p_cursor);EXCEPTIONWHEN OTHERS THENp_errorcode:= SQLCODE;END GetDept;END Em

OPEN p_cursor FOR

SELECT deptno FROM emp WHERE empno = inempno;

RETURN (p_cursor);

EXCEPTION

WHEN OTHERS THEN

p_errorcode:= SQLCODE;

END GetDept;

END Employees; --程序包体定义结束

4 利用ADO调用返回记录集的Oracle存储过程

使用OLE DB和ADO调用返回记录集的Oracle存储过程,在定义ADO对象和设置参数时,需要特定的设置。

4.1 设定数据库连接字符串

在ADO应用程序中,如果要访问返回记录集的Oracle存储过程,需要使用OraOLE DB的数据库连接字符串的指定格式。在连接字符串中,PLSQLRSet属性表明OraOLE DB是否需要从PL/SQL存储过程返回记录集。如果需要返回记录集,PLSQLRSet设为1,否则设置为0,默认为 0。在Command命令执行后,该属性需要设置为0。

4.2 参数的设置

在ADO应用程序中,可以定义调用存储过程的参数。可使用Command对象的CreateParameter 方法创建Parameter 对象,并使用 Append 方法将它们添加到 Parameters 集合,在调用存储过程时,Parameters 集合将参数传递给存储过程。由于OraOLE DB采用定位传递参数的格式,即Command对象在调用存储过程时,调用参数的位置应和存储过程的参数的位置相对应。根据调用的存储过程的参数属性、名称和位置,在ADO中, Append 方法添加参数的次序应和存储过程中参数的顺序一致。

在OLE DB的标准中,没有REF CURSOR类型的预定义数据类型,因此在调用存储过程时,不能创建REF CURSOR类型的参数。在ADO调用返回记录集的存储过程时,OLE DB自动为存储过程中REF CURSOR类型的传出参数返回记录集,该记录集可以赋值给一个Recordset对象。如果PL/SQL存储过程有一个或多个REF CURSOR类型的传出参数,OLE DB将这些参数的记录集集成在一起,并通过第一个REF CURSOR类型的传出参数返回,这些记录集同样可以赋值给一个Recordset对象。

上一页  1 2 3 4 5  下一页

Tags:使用 OLE DB

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接