java跟oracle之间最常用的是java调用oracle的存储过程,以下简要说明下java如何对oracle存储过程进行调用。
java跟oracle之间最常用的是java调用oracle的存储过程,以下简要说明下java如何对oracle存储过程进行调用。
ⅰ、java调用oracle存储过程【不带输出参数】
过程名称为pro1,参数个数1个,数据类型为整形数据。
import java.sql.*;
public class procedurenoargs {
public static void main(string args[]) throws exception {
// 加载oracle驱动
drivermanager.registerdriver(new oracle.jdbc.driver.oracledriver());
// 获得oracle数据库连接
connection conn = drivermanager.getconnection(
jdbc:oracle:thin:@mydbcomputernameorip:1521:orcl, susr, spwd);
// 创建存储过程的对象
callablestatement c = conn.divparecall( {call pro1(?)} );
// 给oracle存储过程的参数设置值 ,,将第一个参数的值设置成188
c.setint(1, 188);
// 执行oracle存储过程
c.execute();
conn.close();
}
}
ⅱ、java调用oracle存储过程【带输出参数的情况】
过程名称为pro2,参数个数2个,数据类型为整形数据,返回值为整形类型
import java.sql.*;
public class procedurewithargs {
public static void main(string args[]) throws exception {
// 加载oracle驱动
drivermanager.registerdriver(new oracle.jdbc.driver.oracledriver());
// 获得oracle数据库连接
connection conn = drivermanager.getconnection(
jdbc:oracle:thin:@mydbcomputernameorip:1521:orcl, susr, spwd);
// 创建oracle存储过程的对象,调用存储过程
callablestatement c = conn.divparecall({call pro2(?,?)});
// 给oracle存储过程的参数设置值 ,将第一个参数的值设置成188
c.setint(1, 188);
// 注册存储过程的第二个参数
c.registeroutparameter(2, java.sql.types.integer);
// 执行oracle存储过程
c.execute();
// 得到存储过程的输出参数值并打印出来
system.out.println(c.getint(2));
conn.close();
}
}
以上即是在java中调用oracle存储过程的最简单的实例,接下来将介绍有关java跟oracle存储过程的其他方面内容。
二、使用java创建oracle存储过程
先看下如何使用java来编写oracle存储过程,我们在oracle的sql plus中编写语句。
ⅰ、启动sql plus
ⅱ、编写java类,定义java类别名,本存储过程为简单地输出传入参数的平方值。
create or replace and compile java source named pf as
/**
* 通过java类来 创建oracle存储过程
*/
package org.oraclejava.pro;
public class javacreatepro {
public static string test(int num) {
return num + 的平方为: + num * num;
}
}
ⅲ、将java类中的方法test创建为一个oracle函数方法
create or replace function pf_fun(name integer) return varchar2 as language java name 'org.oraclejava.pro.javacreatepro.test(java.lang.integer) return java.lang.string';
ⅳ、在控制台直接调用创建的oracle函数
select pf_fun(10) from dual;
ⅴ、输出结果
10的平方为:100