Oracle中返回結(jié)果集的存儲過程分享
更新時間:2012年07月04日 17:34:56 作者:
Oracle不像SQLServer那樣在存儲過程中用Select就可以返回結(jié)果集,而是通過Out型的參數(shù)進行結(jié)果集返回的
Oracle不像SQLServer那樣在存儲過程中用Select就可以返回結(jié)果集,而是通過Out型的參數(shù)進行結(jié)果集返回的。實際上是利用REF CURSOR
--procedure返回記錄集:
----------------------聲明一個Package--------------
CREATE OR REPLACE PACKAGE pkg_test
AS
TYPEmyrctypeIS REF CURSOR;
PROCEDURE get_r(p_id NUMBER,p_rc OUT myrctype); --Package中聲明名為get 的Procedure(只有接口沒內(nèi)容)
END pkg_test;
-----------------聲明Package Body,即上面Package中的內(nèi)容,包括Procedure get---------------------
CREATE OR REPLACE PACKAGE BODY pkg_test
AS
PROCEDURE get_r(p_id NUMBER,p_rc OUT myrctype)
IS
sqlstr VARCHAR2 (500);
BEGIN
IF p_id = 0 THEN
OPEN p_rc FOR
SELECT ID, NAME, sex, address, postcode, birthday
FROM student;
ELSE
sqlstr :=
'select id,name,sex,address,postcode,birthday
from student where id=:w_id'; --w_id是個參數(shù),
--以下 p_rc是個REF CURSOR游標(biāo)類型,而且是OUT型參數(shù),即可返回一個記錄集了。USING p_id就是替換上面SQL中:w_id值拉:)
OPEN p_rc FOR sqlstr USING p_id;
END IF;
END get;
END pkg_test;
--function返回記錄集的例子,原理和上面相同,而是用function的return值來返回記錄集。
函數(shù)返回記錄集:
建立帶ref cursor定義的包和包體及函數(shù):
CREATE OR REPLACE
package pkg_test as
type myrctype is ref cursor;
function get_r(intID number) return myrctype;
end pkg_test;
/
CREATE OR REPLACE
package body pkg_test as
--函數(shù)體
function get_r(intID number) return myrctype is
rc myrctype; --定義ref cursor變量
sqlstr varchar2(500);
begin
if intID=0 then
--靜態(tài)測試,直接用select語句直接返回結(jié)果
open rc for select id,name,sex,address,postcode,birthday from student;
else
--動態(tài)sql賦值,用:w_id來申明該變量從外部獲得
sqlstr := 'select id,name,sex,address,postcode,birthday from student where id=:w_id';
--動態(tài)測試,用sqlstr字符串返回結(jié)果,用using關(guān)鍵詞傳遞參數(shù)
open rc for sqlstr using intid;
end if;
return rc;
end get;
end pkg_test;
復(fù)制代碼 代碼如下:
--procedure返回記錄集:
----------------------聲明一個Package--------------
CREATE OR REPLACE PACKAGE pkg_test
AS
TYPEmyrctypeIS REF CURSOR;
PROCEDURE get_r(p_id NUMBER,p_rc OUT myrctype); --Package中聲明名為get 的Procedure(只有接口沒內(nèi)容)
END pkg_test;
-----------------聲明Package Body,即上面Package中的內(nèi)容,包括Procedure get---------------------
CREATE OR REPLACE PACKAGE BODY pkg_test
AS
PROCEDURE get_r(p_id NUMBER,p_rc OUT myrctype)
IS
sqlstr VARCHAR2 (500);
BEGIN
IF p_id = 0 THEN
OPEN p_rc FOR
SELECT ID, NAME, sex, address, postcode, birthday
FROM student;
ELSE
sqlstr :=
'select id,name,sex,address,postcode,birthday
from student where id=:w_id'; --w_id是個參數(shù),
--以下 p_rc是個REF CURSOR游標(biāo)類型,而且是OUT型參數(shù),即可返回一個記錄集了。USING p_id就是替換上面SQL中:w_id值拉:)
OPEN p_rc FOR sqlstr USING p_id;
END IF;
END get;
END pkg_test;
--function返回記錄集的例子,原理和上面相同,而是用function的return值來返回記錄集。
函數(shù)返回記錄集:
建立帶ref cursor定義的包和包體及函數(shù):
復(fù)制代碼 代碼如下:
CREATE OR REPLACE
package pkg_test as
type myrctype is ref cursor;
function get_r(intID number) return myrctype;
end pkg_test;
/
CREATE OR REPLACE
package body pkg_test as
--函數(shù)體
function get_r(intID number) return myrctype is
rc myrctype; --定義ref cursor變量
sqlstr varchar2(500);
begin
if intID=0 then
--靜態(tài)測試,直接用select語句直接返回結(jié)果
open rc for select id,name,sex,address,postcode,birthday from student;
else
--動態(tài)sql賦值,用:w_id來申明該變量從外部獲得
sqlstr := 'select id,name,sex,address,postcode,birthday from student where id=:w_id';
--動態(tài)測試,用sqlstr字符串返回結(jié)果,用using關(guān)鍵詞傳遞參數(shù)
open rc for sqlstr using intid;
end if;
return rc;
end get;
end pkg_test;
您可能感興趣的文章:
相關(guān)文章
升級和卸載Oracle數(shù)據(jù)庫軟件的命令整理
這篇文章主要介紹了升級和卸載Oracle數(shù)據(jù)庫軟件的命令整理,包括升級時可能用到的查看版本號和備份操作的命令介紹,需要的朋友可以參考下2015-12-12解析PL/SQL Developer導(dǎo)入導(dǎo)出數(shù)據(jù)庫的方法以及說明
本篇文章是對PL/SQL Developer導(dǎo)入導(dǎo)出數(shù)據(jù)庫的方法以及說明進行了詳細的分析介紹,需要的朋友參考下2013-06-06Oracle數(shù)據(jù)庫中建立索引的基本方法講解
這篇文章主要介紹了Oracle數(shù)據(jù)庫中建立索引的基本方法,包括對性能方面進行衡量而給出的一些索引的設(shè)計和使用建議,需要的朋友可以參考下2016-01-01Oracle 11g數(shù)據(jù)庫使用expdp每周進行數(shù)據(jù)備份并上傳到備份服務(wù)器
這篇文章主要介紹了Oracle 11g數(shù)據(jù)庫使用expdp每周進行數(shù)據(jù)備份并上傳到備份服務(wù)器,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-06-06Oracle安裝過程中物理內(nèi)存檢查及臨時temp空間不足問題解決
Oracle安裝過程物理內(nèi)存檢查及臨時temp空間不足的情況,想必有很多的朋友都有遇到過吧,下面與大家分享下具體的解決方法,感興趣的朋友可以參考下哈2013-07-07Oracle導(dǎo)入導(dǎo)出數(shù)據(jù)的幾種方式
今天小編就為大家分享一篇關(guān)于Oracle導(dǎo)入導(dǎo)出數(shù)據(jù)的幾種方式,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-02-02