JDBC调用Oracle存储过程返回结果集并获得输出参数实例

JDBC调用Oracle存储过程返回结果集并获得输出参数的实例是本文我们主要要介绍的内容,接下来我们就开始介绍这一过程,让我们一起来了解一下吧。

 
 
 
  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 Email:fish2-2@163.com   
  11. * @date 2011-08-22   
  12. */    
  13. public class AppTest {    
  14. public static void main(String[] args) throws Exception {    
  15. ApplicationContext context = new ClassPathXmlApplicationContext(    
  16. new String[] { "applicationContext.xml" });    
  17. BeanFactory factory = (BeanFactory) context;    
  18. ComboPooledDataSource dataSource = (ComboPooledDataSource) factory    
  19. .getBean("dataSource");    
  20. Connection con = dataSource.getConnection();    
  21. CallableStatement st =con.prepareCall("{call package_user.PERSON_QUERY(?,?)}");    
  22. //st.setString(1, "");     
  23. st.registerOutParameter(1, oracle.jdbc.OracleTypes.CURSOR);    
  24. st.registerOutParameter(2, oracle.jdbc.OracleTypes.INTEGER);    
  25. st.execute();    
  26. ResultSet rs = null;    
  27. rs = (ResultSet)st.getObject(1);    
  28. while(rs.next())    
  29. {    
  30. System.out.println(rs.getObject(1)+" "+rs.getObject(2));    
  31. }    
  32. int count =st.getInt(2);  //获取输出参数     
  33. System.err.println(count);    
  34. if (rs != null)    
  35. rs.close();    
  36. if (st != null)    
  37. st.close();    
  38. if (con != null)    
  39. con.close();    
  40. }    
  41. }   
 
 
 
  1. CREATE OR REPLACE PACKAGE package_user   AS    
  2. TYPE MY_RESULTSET_CURSOR IS REF CURSOR;    
  3. PROCEDURE PERSON_QUERY(RS OUT MY_RESULTSET_CURSOR,C OUT INTEGER);    
  4. END;    
  5. create or replace package body package_user AS    
  6. PROCEDURE  PERSON_QUERY(RS OUT MY_RESULTSET_CURSOR,C OUT INTEGER)    
  7. AS    
  8. BEGIN    
  9. OPEN RS FOR select * from emp;    
  10. update A set ename='AAA';    
  11. SELECT COUNT(*) INTO C from emp;    
  12. END PERSON_QUERY;    
  13. END;   

以上就是JDBC调用Oracle存储过程返回结果集并获得输出参数的全部过程,本文就介绍到这里了,希望本次的介绍能够对您有所收获!

【编辑推荐】

  1. Oracle数据库诊断工具RDA的安装与使用详解
  2. 图解Access数据库转化为SQLite数据库的方法
  3. Oracle数据库GLOBAL_NAMES参数的详细研究
  4. PostgreSQL数据库中pg_hba.conf文件的使用详解
  5. PostgreSQL安装及Streaming Replication配置详解

当前标题:JDBC调用Oracle存储过程返回结果集并获得输出参数实例
文章地址:http://www.mswzjz.cn/qtweb/news39/374439.html

温江区贝锐智能技术服务部_成都网站建设公司,为您提供微信小程序全网营销推广网站收录网站内链App开发静态网站

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能