JDBC调用带输出参数的存储过程的实例解析_SQL Server_数据库_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 数据库 > SQL Server > JDBC调用带输出参数的存储过程的实例解析

JDBC调用带输出参数的存储过程的实例解析

 2016/5/12 5:35:59    程序员俱乐部  我要评论(0)
  • 摘要:在用JDBC调用存储过程来实现分页的时候,因为要统计分页数据的总数,在存储过程中想到了使用一个输出参数来完成这样的功能,于是就用JDBC调用带输出参数的存储过程来实现这一功能。刚开始还出了点问题,如下:callableStatement.setString(1,"w");callableStatement.registerOutParameter(2,java.sql.Types.INTEGER);ResultSetrs=callableStatement
  • 标签:输出 过程 存储过程 实例 实例解析 解析

在用JDBC调用存储过程来实现分页的时候,因为要统计分页数据的总数,在存储过程中想到了使用一个输出参数来完成这样的功能,于是就用JDBC调用带输出参数的存储过程来实现这一功能。刚开始还出了点问题,如下:

    class="dp-xml">
  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)   

就出现了上面的异常现象。

解决方法是将其改为:

  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调用带输出参数的存储过程来完成分页并统计分页总数的全部过程,本文就介绍到这里了,希望本次的介绍能够对您有所收获!

发表评论
用户名: 匿名