程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle數據庫基礎 >> Oracle存儲過程中不存在返回值的緣由

Oracle存儲過程中不存在返回值的緣由

編輯:Oracle數據庫基礎

以下的文章主要描述的是返回列表,我們大家都知道由於Oracle存儲過程是不存在返回值,Oracle存儲過程所有的返回值皆以out參數替代的,列表同樣也是不例外,但由於是集合,所以不能用一般的參數,必須要用pagkage了.所以要分兩部分,

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

  1. CREATE OR REPLACE PACKAGE TESTPACKAGE AS  
  2. TYPE Test_CURSOR IS REF CURSOR;  
  3. end TESTPACKAGE;  

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

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

可以看到,它是把游標(可以理解為一個指針),作為一個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. }   
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved