JAVA调用Oracle存储过程的实现方法

本文详细介绍了Java如何调用Oracle存储过程,包括不带输出参数和带输出参数两种情况,通过具体实例展示了实现步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

JAVA跟Oracle之间,最常用的操作就是是JAVA调用Oracle存储过程,下面就为您介绍JAVA如何对Oracle存储过程进行调用。

Ⅰ、JAVA调用Oracle存储过程【不带输出参数】
过程名称为pro1,参数个数1个,数据类型为整形数据。

 
  1. import java.sql.*;   
  2.  
  3. public class ProcedureNoArgs {   
  4. public static void main(String args[]) throws Exception {   
  5.     // 加载Oracle驱动   
  6.     DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());   
  7.     // 获得Oracle数据库连接   
  8.     Connection conn = DriverManager.getConnection(   
  9.         " jdbc:oracle:thin:@MyDbComputerNameOrIP:1521:ORCL", sUsr, sPwd);   
  10.     // 创建存储过程的对象   
  11.     CallableStatement c = conn.prepareCall(" {call pro1(?)} ");   
  12.     // 给Oracle存储过程的参数设置值 ,将第一个参数的值设置成188   
  13.     c.setInt(1, 188);   
  14.     // 执行Oracle存储过程   
  15.     c.execute();   
  16.     conn.close();   
  17. }   
  18. }  

Ⅱ、JAVA调用Oracle存储过程【带输出参数的情况】
过程名称为pro2,参数个数2个,数据类型为整形数据,返回值为整形类型

 
  1. import java.sql.*;   
  2.  
  3. public class ProcedureWithArgs {   
  4. public static void main(String args[]) throws Exception {   
  5.     // 加载Oracle驱动   
  6.     DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());   
  7.     // 获得Oracle数据库连接   
  8.     Connection conn = DriverManager.getConnection(   
  9.         "jdbc:oracle:thin:@MyDbComputerNameOrIP:1521:ORCL", sUsr, sPwd);   
  10.     // 创建Oracle存储过程的对象,调用存储过程   
  11.     CallableStatement c = conn.prepareCall("{call pro2(?,?)}");   
  12.     // 给Oracle存储过程的参数设置值 ,将第一个参数的值设置成188   
  13.     c.setInt(1, 188);   
  14.     // 注册存储过程的第二个参数   
  15.     c.registerOutParameter(2, java.sql.Types.INTEGER);   
  16.     // 执行Oracle存储过程   
  17.     c.execute();   
  18.     // 得到存储过程的输出参数值并打印出来   
  19.     System.out.println(c.getInt(2));   
  20.     conn.close();   
  21. }   
  22. }  

以上即是在JAVA中调用Oracle存储过程的最简单的实例。


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值