oracle呼叫儲存過程和函式返回結果集
在程式開發中,常用到返回結果集的儲存過程,這個在MySQL和sql server 裡比較好處理,直接返回查詢結果就可以了,
但在Oracle裡面 要 out 出去,就多了一個步驟,對於不熟悉的兄弟們還得出上一頭汗:),這裡我簡單介紹一下,以供參考,1 定義包
oracle 返回的結果集需要自定義一個 CURSOR (遊標變數)性質的變數,這個要在包頭定義,所以要建立一個包,如下是包頭
Pl/sql程式碼
CREATE OR REPLACE PACKAGE PAK_rstest
IS
TYPE retcursor IS REF CURSOR;
PROCEDURE pro_read
(
outcurse IN OUT retcursor
);
END; -- Package spec
上面是建立了一個名稱為PAK_rstest的包頭,裡面定義了一個CURSOR 型別,型別名為retcursor ,有了這個定義我們就可以用他來返回結果集了,比如該包裡面的 pro_read 過程就是 一個返回結果集的過程,下面是他的包體,
Pl/sql程式碼
CREATE OR REPLACE PACKAGE BODY PAK_rstest IS
PROCEDURE pro_read
(
outcurse IN OUT retcursor
)
IS
begin
OPEN outcurse FOR
select * from tbl_test
where rownum<6;
return;
end;
END;
這樣就定義好了一個包,這個包裡面有個返回結果集的過程 pro_read
2 在程式裡面呼叫,
下面就是如果在程式裡面呼叫了,這裡用Java為例子簡單介紹一下,
假設你現在已經有一個Connection conn 物件連線上了資料庫(如何連線資料庫我這裡就不詳細說了),
則用下面的程式碼呼叫過程,
Pl/sql程式碼
if(conn !=null){
String sqlstr = "{call PAK_SMS2_ROUTE.MO_ISSUE(?)}";
CallableStatement cstmt = conn.prepareCall(sqlstr);
cstmt.registerOutParameter(1, oracle.jdbc.OracleTypes.CURSOR); //outcurse
cstmt.executeUpdate();
ResultSet rs = (ResultSet) cstmt.getObject(1); // 這裡吧資訊已經讀入rs結果集裡面,剩下的大家都熟悉了吧
while (rs.next()) {
System.out.println(rs.getString("s_date1")); //tbl_test 表裡的欄位名稱或是結果集的列名稱
System.out.println(rs.getString("s_date2"));
}
conn.close();
conn = null;
}
好了到這裡就可以看到返回的結果集內容了,是不是比較簡單啊,:)
Oracle 儲存過程返回結果集:
過程返回記錄集程式碼
CREATE OR REPLACE PACKAGE pkg_test
AS
TYPE myrctype IS REF CURSOR;
PROCEDURE get (p_id NUMBER, p_rc OUT myrctype);
END pkg_test;
CREATE OR REPLACE PACKAGE BODY pkg_test
AS
PROCEDURE get (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';
OPEN p_rc FOR sqlstr USING p_id;
END IF;
END get;
END pkg_test;
函式返回記錄集:
建立帶ref cursor定義的包和包體及函式:
函式返回記錄集程式碼
CREATE OR REPLACE
package pkg_test as
/* 定義ref cursor型別
不加return型別,為弱型別,允許動態sql查詢,
否則為強型別,無法使用動態sql查詢;
*/
type myrctype is ref cursor;
--函式申明
function get(intID number) return myrctype;
end pkg_test;
包體程式碼
CREATE OR REPLACE
package body pkg_test as
--函式體
function get(intID number) return myrctype is
rc myrctype; --定義ref cursor變數
sqlstr varchar2(500);
begin
if intID=0 then
--靜態測試,直接用select語句直接返回結果
open rc for select id,name,sex,address,postcode,birthday from
student;
else
--動態sql賦值,用:w_id來申明該變數從外部獲得
sqlstr := 'select id,name,sex,address,postcode,birthday from
student where id=:w_id';
--動態測試,用sqlstr字串返回結果,用using關鍵詞傳遞引數
open rc for sqlstr using intid;
end if;
return rc;
end get;
end pkg_test;
Java呼叫oracle函式返回遊標處理程式碼
CallableStatement cstmt = null;
ResultSet rs = null;
try {
String callSql = "{? = call AAAAA(?)}";
cstmt = conn.prepareCall(callSql);
cstmt.setString(2, "userName");
cstmt.registerOutParameter(1, oracle.jdbc.OracleTypes.CURSOR);
cstmt.execute();
rs = (ResultSet) cstmt.getObject(1);
if (rs != null) {
System.out.print("usercd");
System.out.print("userName");
System.out.println("EMAIL");
while (rs.next()) {
System.out.print(rs.getString(1)+" ");
System.out.print(rs.getString(2)+" ");
System.out.println(rs.getString(3));
}
}