成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

JDBC調用帶輸出參數(shù)的存儲過程的實例解析

數(shù)據(jù)庫 SQL Server
本文我們主要介紹了JDBC調用帶輸出參數(shù)的存儲過程來完成統(tǒng)計分頁數(shù)據(jù)總數(shù)的功能的代碼實例,通過這個實例,讓我們一起來了解一下JDBC調用帶輸出參數(shù)的存儲過程的方法吧,希望能夠對您有所幫助。

在用JDBC調用存儲過程來實現(xiàn)分頁的時候,因為要統(tǒng)計分頁數(shù)據(jù)的總數(shù),在存儲過程中想到了使用一個輸出參數(shù)來完成這樣的功能,于是就用JDBC調用帶輸出參數(shù)的存儲過程來實現(xiàn)這一功能。剛開始還出了點問題,如下:

 

  1. callableStatement.setString(1, "w");    
  2. callableStatement.registerOutParameter(2, java.sql.Types.INTEGER);    
  3. ResultSet rs = callableStatement.executeQuery();    
  4. int out = callableStatement.getInt(2);    
  5. while (rs.next()) {    
  6. System.out.println(rs.getObject("PERSON_NAME"));    
  7. }   

 

如果先調用 int out = callableStatement.getInt(2);的話,結果集就會被關閉,并拋出

 

  1. Exception in thread "main" com.microsoft.sqlserver.jdbc.SQLServerException: 結果集已關閉。  
  2. at com.microsoft.sqlserver.jdbc.SQLServerException.makeFromDriverError(Unknown Source)    
  3. at com.microsoft.sqlserver.jdbc.SQLServerResultSet.checkClosed(Unknown Source)    
  4. at com.microsoft.sqlserver.jdbc.SQLServerResultSet.next(Unknown Source)    
  5. at com.mchange.v2.c3p0.impl.NewProxyResultSet.next(NewProxyResultSet.java:2859)    
  6. at xx.qq.app.AppTest.main(AppTest.java:24)   

 

就出現(xiàn)了上面的異常現(xiàn)象。

解決方法是將其改為:

 

  1. ResultSet rs = callableStatement.executeQuery();    
  2. while (rs.next()) {    
  3. System.out.println(rs.getObject("PERSON_NAME"));    
  4. }    
  5. int out = callableStatement.getInt(2);   

 

這樣就OK了。

附上簡單的存儲過程及源碼:

 

  1. package xx.qq.app;    
  2. import java.sql.CallableStatement;    
  3. import java.sql.Connection;    
  4. import java.sql.ResultSet;    
  5. import org.springframework.beans.factory.BeanFactory;    
  6. import org.springframework.context.ApplicationContext;    
  7. import org.springframework.context.support.ClassPathXmlApplicationContext;    
  8. import com.mchange.v2.c3p0.ComboPooledDataSource;    
  9. /**   
  10. * @author Jack Zhang    
  11. *         Email:fish2-2@163.com   
  12. * @date 2011-08-22   
  13. */    
  14. public class AppTest {    
  15. public static void main(String[] args) throws Exception {    
  16. ApplicationContext context = new ClassPathXmlApplicationContext(    
  17. new String[] { "applicationContext.xml" });    
  18. BeanFactory factory = (BeanFactory) context;    
  19. ComboPooledDataSource dataSource = (ComboPooledDataSource) factory    
  20. .getBean("dataSource");    
  21. Connection con = dataSource.getConnection();    
  22. CallableStatement callableStatement = con    
  23. .prepareCall("{call GetBasics(?,?)}");    
  24. callableStatement.setString(1, "w");    
  25. callableStatement.registerOutParameter(2, java.sql.Types.INTEGER);    
  26. ResultSet rs = callableStatement.executeQuery();    
  27. while (rs.next()) {    
  28. System.out.println(rs.getObject("PERSON_NAME"));    
  29. }    
  30. int out = callableStatement.getInt(2);    
  31. //int out = callableStatement.getInt(2);     
  32. System.out.println(out);    
  33. if (rs != null)    
  34. rs.close();    
  35. if (callableStatement != null)    
  36. callableStatement.close();    
  37. if (con != null)    
  38. con.close();    
  39. }    
  40. }    
  41. /**   
  42. *    
  43. * QueryTemplate queryTemplate =(QueryTemplate)factory.getBean("queryTemplate"); //   
  44. * queryTemplate.query(new Query(){ // public void executeQuery(Connection con,   
  45. * Statement st, ResultSet rs) throws Exception { // String sql ="SELECT * FROM   
  46. * P_BASIC"; // rs = st.executeQuery(sql); // while(rs.next()) // { //   
  47. * System.out.println(rs.getObject(5)); // } // } // });   
  48. *    
  49. */   

 

存儲過程

 

  1. ALTER PROCEDURE GetBasics(    
  2. @PERSON_NAME VARCHAR(32),    
  3. @COUNT INT OUT    
  4. )    
  5. AS    
  6. BEGIN    
  7. SELECT @COUNTCOUNT = COUNT(*) FROM P_BASIC;    
  8. SELECT * FROM P_BASIC    
  9. END    
  10. GO   

 

以上就是JDBC調用帶輸出參數(shù)的存儲過程來完成分頁并統(tǒng)計分頁總數(shù)的全部過程,本文就介紹到這里了,希望本次的介紹能夠對您有所收獲!

【編輯推薦】

  1. Oracle 11g數(shù)據(jù)庫使用XML Table的BUG解決
  2. SQL Server 2005數(shù)據(jù)庫游標調用函數(shù)實例解析
  3. SQL Server數(shù)據(jù)庫中FOR XML AUTO的使用詳解
  4. SQL Server數(shù)據(jù)庫用視圖來處理復雜的數(shù)據(jù)查詢關系
  5. SQL Server,Oracle,DB2上創(chuàng)建表和修改表對比與總結
責任編輯:趙鵬 來源: CSDN博客
相關推薦

2011-08-25 09:31:43

JDBC調用Oracl

2011-08-25 11:36:50

PreparedStaJDBC存儲過程調用

2010-10-08 16:55:44

MySql存儲過程

2009-07-08 17:17:16

JDBC調用存儲過程

2009-07-22 15:58:34

JDBC調用Oracl

2009-11-11 11:27:02

ADO.NET存儲過程

2009-06-22 11:04:00

Jdbc存儲過程

2010-11-10 15:16:14

Sql Server分

2009-06-17 10:33:17

Hibernate 存

2010-03-30 12:50:42

Oracle存儲

2011-08-12 11:22:53

Oracle存儲過程Java

2010-11-16 14:30:32

Oracle存儲過程

2009-07-17 13:54:51

JDBC存儲過程

2009-07-23 14:10:38

Hibernate J

2010-10-09 16:26:59

mysql存儲過程

2010-04-16 12:38:37

Oracle集合類型

2010-10-26 14:50:11

oracle存儲過程

2010-04-16 11:39:56

Oracle存儲過程

2009-07-08 17:42:33

JDBC存儲過程

2009-01-19 08:59:04

PHP調用MySQL存儲過程MySQLi擴展
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 免费av观看 | 免费高清av | 亚洲一区中文字幕在线观看 | 亚洲精品一区二区三区四区高清 | 日韩成人免费视频 | 国产精品一区二区不卡 | 91精品国产91久久综合桃花 | 久久精品国产一区老色匹 | 午夜一区二区三区视频 | 成人三区四区 | 日韩电影一区二区三区 | 日韩成人精品在线观看 | 91综合网 | 九九热九九 | 欧美成人一级视频 | 成人在线一区二区 | 亚洲一区二区三区视频在线 | 精品国产91 | 国产在线精品一区二区三区 | 国产精品久久久亚洲 | 国产精品免费在线 | 日本网站在线看 | 亚洲国产中文字幕 | 欧美精品一区三区 | 亚洲精品视频免费 | 在线观看成人小视频 | 国产一级视频在线播放 | 九色在线观看 | 免费黄色片在线观看 | 一区免费观看 | 天天曰夜夜操 | 久久国产精品-国产精品 | 亚洲视频在线一区 | 色永久 | 五月激情婷婷在线 | 成人av电影免费在线观看 | 浴室洗澡偷拍一区二区 | 国产精品性做久久久久久 | 日韩一区二区在线视频 | 日韩一区二区视频 | 婷婷丁香激情 |