oracle存儲過程返回遊標
⑴ 求助:在oracle中用存儲過程返回遊標(前先判斷游標是否有值)的問題
可以繞個彎...
先可以用select
count(*)
查詢你游標的結果集,判斷一下如果大於0
則說明有值,如果等於0就沒有值,有值就繼續執行打開游標,沒有值的話就返回
DBMS_OUTPUT.PUT_LINE('沒有返回值');
⑵ oracle 存儲過程返回遊標只能在package里嗎
存儲過程沒有返回值,只有出參,類似函數的返回值。如果查詢列表,就要以游標作為out參數,而游標是不能直接作為一個過程參數的,所以只能定義在包里使用。
⑶ 求助:在oracle中用存儲過程返回遊標(前先判斷游標是否有值)的問題
游標只有fetch了才能判斷是否有值,所以只能用select count(*)先判斷了
⑷ pdo 怎麼調用oracle 返回遊標的存儲過程
有倆種方法:
一種是聲明系統游標,一種是聲明自定義游標,然後後面操作一樣,參數類型為
in
out
或out
(1)聲明個人系統游標.(推薦)
create
or
replace
p_temp_procere
(
cur_arg
out
sys_refcursor;
--方法1
)
begin
open
cur_arg
for
select
*
f...
⑸ oracle不可以通過調用dblink存儲過程/函數返回結果集游標嗎
如果一個procere要返回一個結果集,那麼要引用游標來處理這個結果集。
create or replace procere Test
(
varEmpName emp.ename%type
)
As
begin ------會報錯.錯誤原因沒有into子句.
select * from emp where ename like '%'||varEmpName||'%';
end;
這個程序我們無法用into,因為在Oracle裡面沒有一個類型去接受一個結果集.這個時候我們可以聲明游標對象去接受他.
⑹ Oracle調用存儲過程輸出的游標問題
不知道你那裡。
是不是可以把那個 存儲過程 (參數是游標)的。
修改為 函數, 返回遊標。
如果可以修改的話, 那麼你參考一下 下面這個例子代碼
sql">--測試表數據。
select*fromtest_main;
IDVALUE
------------------------------
1ONE
3THREE
2TWO
--返回結果集的函數.
CREATEORREPLACEFUNCTIONGet_Test_Main_All
RETURNSYS_REFCURSOR
IS
return_cursorSYS_REFCURSOR;
BEGIN
OPENreturn_cursorFOR'SELECT*FROMtest_main';
RETURNreturn_cursor;
END;
/
--普通的查詢,來查看結果.
SELECTGet_Test_Main_All()FROMal;
GET_TEST_MAIN_ALL()
--------------------
CURSORSTATEMENT:1
CURSORSTATEMENT:1
IDVALUE
------------------------------
1ONE
3THREE
2TWO
--存儲過程調用,來獲取結果.
DECLARE
--調用函數的返回值.
testCursorSYS_REFCURSOR;
--存儲單行數據.
testRectest_main%ROWTYPE;
BEGIN
--調用返回結果集的函數.
testCursor:=Get_Test_Main_All();
--循環,遍歷結果.
LOOP
--游標向前.
FETCHtestCursorINTOtestRec;
--無數據的情況下,退出循環.
EXITWHENtestCursor%NOTFOUND;
--輸出調試信息.
dbms_output.put_line(TO_CHAR(testRec.id)||''||testRec.value);
ENDLOOP;
END;
/
1ONE
3THREE
2TWO
PL/SQL過程已成功完成。
⑺ 如何在oracle存儲過程中返回遊標
1:首先你需要創建一個包,並定義你返回的游標的類型、存儲過程 create or replace package TEST_PKG is -- Public type declarations type cur_emp is REF CURSOR; procere test_proc (v_empno in number, emps out cur_emp); end TEST_PKG; 2:然後你再創建包體 create or replace package body TEST_PKG is procere test_proc (v_empno in number, emps out cur_emp)asbeginopen emps for select * from emp where empno=7369; end test_proc; end TEST_PKG ; 3,通過JAVA調用 cstmt = conn.prepareCall("{call TEST_PKG .test_proc (?)}"); cstmt.registerOutParameter(1, OracleTypes.CURSOR); cstmt.execute();//獲得結果集
⑻ oracle存儲過程返回遊標類型是為什麼不能把游標放到rowtype的變數中
SELECT * FROM (
SELECT ROWNUM AS r , e.* FROM (
SELECT * FROM employees
) e
) WHERE r BETWEEN ' || v_pre || ' AND ' || v_next;
結果集裡面多了一個r
SELECT ROWNUM AS r