Sys_refcursor
来源:互联网 发布:软件开发口号大全 编辑:程序博客网 时间:2024/06/05 02:16
在很多時候我們需要通過bind var來提高整個DB的performance,在我們用第三次開發軟件做對結果集的查詢。我們如何在procedure中完成對結果集的查詢呢,從oracle7.3才被支持,在9i以后又有新的變化,在9i以前要define一個type才可以。而在9i以后oracle引入了一個新的類型為sys_refcursor,這樣就不需要我們重新定義。我們來看一個例子吧。
C:oracleora92sqlplusdemo>sqlplus /nolog
SQL*Plus: Release 9.2.0.1.0 - Production on 星期六 4月 2 11:09:06 2005
Copyright (c) 1982, 2002, Oracle Corporation. All rights reserved.
SQL> conn scott/tiger@vongates
connected.
SQL> create or replace procedure getEmpByDept(in_deptNo in emp.deptno%type,
2 out_curEmp out SYS_REFCURSOR) as
3
4 begin
5 open out_curEmp for
6 SELECT * FROM emp WHERE deptno = in_deptNo ;
7 EXCEPTION
8 WHEN OTHERS THEN
9 RAISE_APPLICATION_ERROR(-20101,
10 'Error in getEmpByDept' || SQLCODE );
12 end getEmpByDept;
13 /
已建立程序.
SQL> var rset refcursor;
SQL> exec getEmpByDept(10,:rset);
PL/SQL 程序順利完成.
SQL> print rset;
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
---------- -------------------- ------------------ ---------- ---------- ---------- ---------- ----------
7934 MILLER CLERK 7782 23-1月 -82 1300 10
7782 CLARK MANAGER 7839 09-1月 -81 2450 10
7839 KING PRESIDENT 17-11月-81 5000 10
SQL>
另一个例子:
CREATE OR REPLACE PROCEDURE P_RETR_CURSOR
(P_ID IN NUMBER,
P_RECSET OUT SYS_REFCURSOR) AS
--Created by xsb on 2004-11-09 For: 存储过程返回记录集
BEGIN
OPEN P_RECSET FOR
SELECT *
FROM t
WHERE c1 = P_ID;
END;
--------------------------------------------------------------
DECLARE
--Created by xsb on 2004-11-09 For: 存储过程返回记录集测试
--set serveroutput on
I NUMBER;
S VARCHAR2(100);
M SYS_REFCURSOR;
BEGIN
FOR J IN 1 .. 10 LOOP
P_RETR_CURSOR(J, M);
FETCH M
INTO S, I;
DBMS_OUTPUT.PUT(I || '-');
DBMS_OUTPUT.PUT_LINE(S);
CLOSE M;
END LOOP;
END;
/
- Sys_refcursor
- SYS_REFCURSOR
- SYS_REFCURSOR
- SYS_REFCURSOR一例
- sys_refcursor的用法实例
- function返回sys_refcursor
- SYS_REFCURSOR & REF CURSOR
- Ref Cursor / sys_refcursor
- ORACLE的引用游标SYS_REFCURSOR
- ORACLE的引用游标SYS_REFCURSOR
- Oracle 参照游标(SYS_REFCURSOR)使用
- sys_refcursor 和 cursor 优缺点比较
- sys_refcursor的使用(oracle自定义游标)
- cursor 与refcursor及sys_refcursor的区别
- ORACL可用SYS_REFCURSOR 返回结果集.
- ORACL可用SYS_REFCURSOR 返回结果集.
- cursor 与refcursor及sys_refcursor的区别
- oracle存储过程返回结果集SYS_REFCURSOR
- B 树、B- 树、B+ 树、B* 树都是什么
- 初来乍到
- 如何让网页div图层居中显示
- 不可恢复的生成错误
- IDE SATA 硬盘类型的比较
- Sys_refcursor
- @Page指令之AutoEventWireup属性小解
- Socket編程--簡單非同步(異步)服務端與客戶端示例
- 让你的程序更加完美
- 处理CSV格式行的算法
- 关于中文乱码问题的一些解决方案和经验
- 第二章 用户接口 第一节 简介
- 第二章 第二节 取得键盘输入
- 2007年十大财经新闻