程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle數據庫基礎 >> Oracle存儲過程的返回列表如何以java來調用

Oracle存儲過程的返回列表如何以java來調用

編輯:Oracle數據庫基礎

以下的文章主要是向你介紹的是如何用Java來調用Oracle存儲過程的返回列表以為Oracle存儲過程中沒有返回值,它的所有返回值都通過相關參數來替代,等等操作,你如果對Java來調用Oracle存儲過程的返回列表的實際操作感興趣的話,可以浏覽我們的文章。

列表同樣也不例外,但由於是集合,所以不能用一般的參數,必須要用pagkage了.所以要分兩部分,

1, 建一個程序包。如下:

CREATE OR REPLACE PACKAGE TESTPACKAGE AS
TYPE Test_CURSOR IS REF CURSOR;
end TESTPACKAGE;

2,建立存儲過程,存儲過程為:

CREATE OR REPLACE PROCEDURE TESTC(p_CURSOR out TESTPACKAGE.Test_CURSOR) IS
BEGIN
OPEN p_CURSOR FOR SELECT * FROM HYQ.TESTTB;
END TESTC;

可以看到,Oracle存儲是把游標(可以理解為一個指針),作為一個out 參數來返回值的。在Java裡調用時就用下面的代碼:

  1. package com.hyq.src;  
  2. import Java.sql.*;  
  3. import Java.io.OutputStream;  
  4. import Java.io.Writer;  
  5. import Java.sql.PreparedStatement;  
  6. import Java.sql.ResultSet;  
  7. import Oracle.jdbc.driver.*;  
  8. public class TestProcedureTHREE {  
  9. public TestProcedureTHREE() {  
  10. }  
  11. public static void main(String[] args ){  
  12. String driver = "oracle.jdbc.driver.OracleDriver";  
  13. String strUrl = "jdbc:Oracle:thin:@127.0.0.1:1521:hyq";  
  14. Statement stmt = null;  
  15. ResultSet rs = null;  
  16. Connection conn = null;  
  17. try {  
  18. Class.forName(driver);  
  19. conn = DriverManager.getConnection(strUrl, "hyq", "hyq");  
  20. CallableStatement proc = null;  
  21. proc = conn.prepareCall("{ call hyq.testc(?) }");  
  22. proc.registerOutParameter(1,oracle.jdbc.OracleTypes.CURSOR);  
  23. proc.execute();  
  24. rs = (ResultSet)proc.getObject(1);  
  25. while(rs.next())  
  26. {  
  27. System.out.println("<tr><td>" + rs.getString(1)
     + "</td><td>"+rs.getString(2)+"</td></tr>");  
  28. }  
  29. }  
  30. catch (SQLException ex2) {  
  31. ex2.printStackTrace();  
  32. }  
  33. catch (Exception ex2) {  
  34. ex2.printStackTrace();  
  35. }  
  36. finally{  
  37. try {  
  38. if(rs != null){  
  39. rs.close();  
  40. if(stmt!=null){  
  41. stmt.close();  
  42. }  
  43. if(conn!=null){  
  44. conn.close();  
  45. }  
  46. }  
  47. }  
  48. catch (SQLException ex1) {  
  49. }  
  50. }  
  51. }  
  52. }   

在這裡要注意,在執行前一定要先把Oracle的驅動包放到class路徑裡,否則會報錯的.以上就是對用Java調用Oracle存儲過程的返回列表相關的內容的介紹,望你會有所收獲。
 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved