oracle 在一個(gè)存儲(chǔ)過(guò)程中調(diào)用另一個(gè)返回游標(biāo)的存儲(chǔ)過(guò)程
SQL-Code:
CREATE OR REPLACE PROCEDURE P_TESTA (
PRESULT OUT SYS_REFCURSOR
)
AS
BEGIN
OPEN PRESULT FOR SELECT * FROM USERS;
END P_TESTA;
其中USERS就是數(shù)據(jù)庫(kù)中一個(gè)表。在調(diào)用的時(shí)候只要聲明一個(gè)該表的ROWTYPE類(lèi)型就可以了:
SQL-Code:
CREATE OR REPLACE PROCEDURE P_TESTB
AS
VARCURSOR SYS_REFCURSOR;
R USERS%ROWTYPE;
BEGIN
P_TESTA(VARCURSOR);
LOOP
FETCH VARCURSOR INTO R;
EXIT WHEN VARCURSOR%NOTFOUND;
DBMS_OUTPUT.PUT_LINE(R.NAME);
END LOOP;
END P_TESTB;
第二種情況,我們返回的不是表的所有的列,或許只是其中一列或兩列,如:
SQL-Code:
CREATE OR REPLACE PROCEDURE P_TESTA (
PRESULT OUT SYS_REFCURSOR
)
AS
BEGIN
OPEN PRESULT FOR SELECT ID,NAME FROM USERS;
END P_TESTA;
這里我們只返回了USERS表的ID,NAME這兩個(gè)列,那么調(diào)用的時(shí)候也必須做相應(yīng)的修改:
SQL-Code:
CREATE OR REPLACE PROCEDURE P_TESTB
AS
VARCURSOR SYS_REFCURSOR;
CURSOR TMPCURSOR IS SELECT ID,NAME FROM USERS WHERE ROWNUM=1;
R TMPCURSOR%ROWTYPE;
BEGIN
P_TESTA(VARCURSOR);
LOOP
FETCH VARCURSOR INTO R;
EXIT WHEN VARCURSOR%NOTFOUND;
DBMS_OUTPUT.PUT_LINE(R.ID);
END LOOP;
END P_TESTB;
與之前不同的是我們聲明了一個(gè)游標(biāo)類(lèi)型的變量TMPCURSOR ,注意TMPCURSOR 的結(jié)構(gòu)必須與存儲(chǔ)過(guò)程P_TESTA 返回的游標(biāo)結(jié)構(gòu)一致,否則就會(huì)出現(xiàn)錯(cuò)誤。同理只要保持兩個(gè)游標(biāo)類(lèi)型結(jié)構(gòu)一致,就可以實(shí)現(xiàn)自由調(diào)用。
- Oracle存儲(chǔ)過(guò)程基本語(yǔ)法介紹
- oracle 存儲(chǔ)過(guò)程和函數(shù)例子
- oracle 存儲(chǔ)過(guò)程詳細(xì)介紹(創(chuàng)建,刪除存儲(chǔ)過(guò)程,參數(shù)傳遞等)
- Oracle中返回結(jié)果集的存儲(chǔ)過(guò)程分享
- Oracle存儲(chǔ)過(guò)程及調(diào)用
- Oracle存儲(chǔ)過(guò)程返回游標(biāo)實(shí)例詳解
- Oracle存儲(chǔ)過(guò)程和存儲(chǔ)函數(shù)創(chuàng)建方法(詳解)
- Oracle存儲(chǔ)過(guò)程入門(mén)學(xué)習(xí)基本語(yǔ)法
- oracle數(shù)據(jù)庫(kù)中查看系統(tǒng)存儲(chǔ)過(guò)程的方法
- Oracle存儲(chǔ)過(guò)程新手入門(mén)教程(附學(xué)習(xí)用例)
相關(guān)文章
Oracle 數(shù)組的學(xué)習(xí) 小知識(shí)也要積累,養(yǎng)成好的學(xué)習(xí)態(tài)度
小知識(shí)也要積累,養(yǎng)成好的學(xué)習(xí)態(tài)度 Oracle的數(shù)組的學(xué)習(xí)2009-08-08ORACLE應(yīng)用經(jīng)驗(yàn)(2)
ORACLE應(yīng)用經(jīng)驗(yàn)(2)...2007-03-03Oracle連接出現(xiàn)ora-12154無(wú)法解析指定的連接標(biāo)識(shí)符
這篇文章主要介紹了Oracle連接出現(xiàn)ora-12154無(wú)法解析指定的連接標(biāo)識(shí)符,需要的朋友可以參考下2017-03-03Oracle數(shù)據(jù)庫(kù)的啟動(dòng)與關(guān)閉方法
這篇文章主要介紹了Oracle數(shù)據(jù)庫(kù)的啟動(dòng)與關(guān)閉方法,需要的朋友可以參考下2013-07-07Oracle9i的全文檢索技術(shù)開(kāi)發(fā)者網(wǎng)絡(luò)Oracle
Oracle9i的全文檢索技術(shù)開(kāi)發(fā)者網(wǎng)絡(luò)Oracle...2007-03-03Oracle中 關(guān)于數(shù)據(jù)庫(kù)存儲(chǔ)過(guò)程和存儲(chǔ)函數(shù)的使用
本篇文章,小編將為大家介紹,在Oracle中 關(guān)于數(shù)據(jù)庫(kù)存儲(chǔ)過(guò)程和存儲(chǔ)函數(shù)的使用,有需要的朋友可以參考一下2013-04-04Oracle進(jìn)階DECODE函數(shù)使用詳解
這篇文章介紹了Oracle進(jìn)階DECODE函數(shù)的使用方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-12-12Oracle中行列轉(zhuǎn)換的實(shí)現(xiàn)方法匯總
行列轉(zhuǎn)換是指將行數(shù)據(jù)轉(zhuǎn)換為列數(shù)據(jù),或?qū)⒘袛?shù)據(jù)轉(zhuǎn)換為行數(shù)據(jù)的過(guò)程,本文主要介紹了Oracle中行列轉(zhuǎn)換的實(shí)現(xiàn)方法匯總,用PIVOT和UNPIVOT函數(shù)來(lái)實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2024-02-02Oracle中instr和substr存儲(chǔ)過(guò)程詳解
這篇文章主要介紹了Oracle中instr和substr存儲(chǔ)過(guò)程詳解,需要的朋友可以參考下2017-02-02