返回cursor的話,那么必須要cursor的手段來處理,不能作為查詢語句的目的表。
成都創(chuàng)新互聯(lián)是少有的成都網(wǎng)站制作、網(wǎng)站建設(shè)、營銷型企業(yè)網(wǎng)站、小程序開發(fā)、手機(jī)APP,開發(fā)、制作、設(shè)計(jì)、賣鏈接、推廣優(yōu)化一站式服務(wù)網(wǎng)絡(luò)公司,從2013年創(chuàng)立,堅(jiān)持透明化,價(jià)格低,無套路經(jīng)營理念。讓網(wǎng)頁驚喜每一位訪客多年來深受用戶好評
如果需要在函數(shù)返回一個(gè)可以供查詢語句使用的結(jié)果集,那么該函數(shù)的返回類型應(yīng)該定義為一個(gè)索引表類型(一個(gè)table類型),然后在查詢語句中使用table函數(shù)將函數(shù)返回的索引表轉(zhuǎn)換成查詢可以使用的目的表。示例如下:
1. 創(chuàng)建返回索引表所需的類型
create or replace type type_rec is object (idx integer, user_name varchar2(50));
create or replace type type_tb is table of type_rec;
2. 創(chuàng)建函數(shù)
create or replace function fn_return_tb
return type_tb
is
o_tb type_tb := type_tb();
i number := 0;
begin
for v_rec in (select 1 as idx, 'Andy' as user_name from dual
union select 2, 'Jack' from dual
union select 3, 'Paul' from dual) loop
o_tb.extend;
i := i + 1;
o_tb(i) := type_rec (v_rec.idx, v_rec.user_name);
end loop;
return o_tb;
end fn_return_tb;
3. 調(diào)用函數(shù)
select s.*
from table(fn_return_tb()) s;
這個(gè)存儲過程你可以在TEST的環(huán)境下查看結(jié)果,不過你需要隱式游標(biāo)來進(jìn)行操作,那樣才能看到,具體步驟如下:
1、首先我們要借助游標(biāo),因此需要先定義一個(gè)返回類型的游標(biāo)
create or replace package type_difinition
as
type mycursor is ref cursor;
end type_difinition;
2、改寫你的存儲過程,要想查看執(zhí)行SQL后結(jié)果需要一個(gè)返回參數(shù),這個(gè)參數(shù)即上面定義的游標(biāo)
類型
create or replace procedure select_pro(
p_result out type_difinition.mycursor -- 返回結(jié)果
)
is
syn_sql varchar2(200) default '';
begin
syn_sql := 'select * from emp';
-- 此處打開游標(biāo),并把需執(zhí)行的SQL賦值給游標(biāo)
open p_result for syn_sql;
end select_pro;
3、執(zhí)行編譯通過后,右鍵點(diǎn)擊存儲過程的名字,跳出框,選擇Test一項(xiàng),進(jìn)入Test界面
4、點(diǎn)擊編譯、再點(diǎn)擊執(zhí)行
5、Test界面的底部界面,有個(gè)Variable Type value的列表,此時(shí)你可以點(diǎn)擊Value值里面的
... 按鈕,即可查看結(jié)果,由于不怎么會應(yīng)用這個(gè)編輯器,本想把圖片上傳給你,如有不解,再詳問,希望回答對樓主有幫助
Oracle的存儲過程和函數(shù)并不能直接返回查詢結(jié)果集(并非不能,“沒有做不到,只有想不到”,呵)。也就是說在Oracle存儲過程或函數(shù)中直接寫查詢返回結(jié)果集是非法的(在SQL Server是可以的)。
與SQL Server的存儲過程和函數(shù)均可以返回結(jié)果集不同的是,PL/SQL的存儲過程和函數(shù)均不直接提供返回?cái)?shù)據(jù)集的方法,但可以通過返回類型對象來實(shí)現(xiàn)返回?cái)?shù)據(jù)集的效果。具體思路為:
(1)創(chuàng)建包頭,在其中聲明類型和存儲過程,類型應(yīng)該引用游標(biāo);
(2)創(chuàng)建包體,定義存儲過程,執(zhí)行查詢,將查詢得到的結(jié)果集以游標(biāo)句柄的形式返回。
說明:游標(biāo)分為顯示游標(biāo)和隱式游標(biāo),任何查詢結(jié)果默認(rèn)都提供隱式游標(biāo),當(dāng)前方案的重點(diǎn)在于使用游標(biāo)取得查詢結(jié)果的句柄,由于游標(biāo)被引用為類型,通過返回類型,即等效于(并不等同)返回?cái)?shù)據(jù)集。
具體的案例如下:
--創(chuàng)建包頭
create or replace package mypackage1
as
--聲明類型,并引用游標(biāo)
type cursorType is ref cursor;
--聲明存儲過程,兩個(gè)輸入?yún)?shù),一個(gè)輸出參數(shù),輸出游標(biāo)類型數(shù)據(jù)
procedure prcGetGlobalAddress
(
pos1 integer, --分頁查詢的下限
pos2 integer, --分頁查詢的上限
cur in out mypackage1.cursorType --輸出參數(shù),數(shù)據(jù)類型為引用游標(biāo)的類型
);
end mypackage1;
--創(chuàng)建包體
create or replace package body mypackage1
as
--定義存儲過程
procedure prcGetGlobalAddress
(
pos1 integer,
pos2 integer,
cur in out mypackage1.cursorType
)
as
begin
--返回得到分頁查詢結(jié)果集的游標(biāo)句柄
open cur for
select *
from ( select a.*,rownum rn
from ( select *
from tblsys_globaladdress) a
where rownum=pos2)
where rn =pos1;
end prcGetGlobalAddress;
end mypackage1;
如果你只是返回幾個(gè)值,請用OUT標(biāo)記輸出參數(shù),查詢代碼為
SELECT SName INTO stuname FROM Student WHERE SID = stuid;
記得一定要用INTO關(guān)鍵字。
總之一句話,在Oracle中,在存儲過程和函數(shù)中都不能直接返回查詢結(jié)果集(哪怕只有1行1列也不行,這是絕對的),但可以通過變通方式實(shí)現(xiàn)。
Oracle中函數(shù)/過程返回結(jié)果集的幾種方式
原文 Oracle中函數(shù)/過程返回結(jié)果集的幾種方式
Oracle中函數(shù)/過程返回結(jié)果集的幾種方式:
以函數(shù)return為例,存儲過程只需改為out參數(shù)即可,在oracle 10g測試通過.
(1) 返回游標(biāo):
return的類型為:SYS_REFCURSOR
之后在IS里面定義變量:curr SYS_REFCURSOR;
最后在函數(shù)體中寫:
open cur for
select ......;
return cur;
當(dāng)前標(biāo)題:oracle終端怎么返回,oracle 函數(shù)返回值 列表
文章出自:http://chinadenli.net/article8/hecpop.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)建站、、企業(yè)建站、企業(yè)網(wǎng)站制作、小程序開發(fā)、響應(yīng)式網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容