JDBC调用Oracle存储过程返回结果集并获得输出参数实例_Oracle_数据库_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 数据库 > Oracle > JDBC调用Oracle存储过程返回结果集并获得输出参数实例

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

 2013/8/10 1:21:20    程序员俱乐部  我要评论(0)
  • 摘要:JDBC调用Oracle存储过程返回结果集并获得输出参数的实例是本文我们主要要介绍的内容,接下来我们就开始介绍这一过程,让我们一起来了解一下吧。packagexx.qq.app;importjava.sql.CallableStatement;importjava.sql.Connection;importjava.sql.ResultSet;importorg.springframework.beans.factory.BeanFactory;importorg
  • 标签:输出 ORA 结果 过程 存储过程 实例 Oracle Oracle存储过程

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

    class="dp-xml">
  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存储过程返回结果集并获得输出参数的全部过程,本文就介绍到这里了,希望本次的介绍能够对您有所收获!

发表评论
用户名: 匿名