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

数据库 Oracle
本文我们主要介绍了JDBC 调用Oracle存储过程返回结果集并获得输出参数的一个实例,通过这个实例,让我们一起来了解一下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配置详解
责任编辑:赵鹏 来源: CSDN博客
相关推荐

2011-08-23 13:14:05

JDBC带输出参数的存储过程

2011-08-23 10:14:09

JDBC更新计数行调用存储过程SQL Server

2009-07-08 17:42:33

JDBC存储过程

2011-08-29 15:52:19

SQL ServerMybatis存储过程

2009-07-22 15:58:34

JDBC调用Oracl

2011-08-18 17:32:40

Oracle存储过程利用游标返回结果集

2011-08-25 09:17:31

Java调用存储过程返回一行或多行结果集

2009-07-08 17:17:16

JDBC调用存储过程

2011-08-25 11:36:50

PreparedStaJDBC存储过程调用

2010-05-07 13:03:01

Oracle通过存储过

2010-01-08 13:23:38

ibmdwInfoSphere

2009-09-17 10:27:55

linq存储过程

2010-04-16 12:38:37

Oracle集合类型

2009-03-25 10:48:08

存储银行Oracle

2011-04-13 09:45:15

Oracle存储

2010-11-16 14:30:32

Oracle存储过程

2010-10-26 14:40:31

oracle存储过程

2010-03-30 13:30:49

Oracle存储

2010-04-30 14:22:43

Oracle通过

2009-06-22 11:04:00

Jdbc存储过程
点赞
收藏

51CTO技术栈公众号