在学习了存储过程和存储函数以后,本文将阐述通过jdbc访问访问oracle的存储过程和存储函数。
1 前提约束
- oracle已经安装完毕,scott用户也已经解锁【作者使用的是oracle11g】
- 已安装jdk,并配置环境变量
- 熟练使用idea
- 熟练使用sqldeveloper
- 熟悉存储过程和函数
2 操作
- 1 以scott登录打开sqldeveloper,创建存储过程和存储函数
# 创建存储过程,入参为用户编号,出参为用户姓名
create or replace procedure pro_demo (no in emp.empno%type,username out emp.ename%type)
is
begin
select ename into username from emp where empno=no;
end;
# 创建存储函数,给入参加10,返回结果
create or replace function fun_demo(num number) return number
is
v_num number(10);
begin
v_num:=num+10;
return v_num;
end;
- 2 在idea创建一个项目,加入oracle驱动包,加入测试类
# TestProcedure.java,存储过程测试类
import java.sql.*;
public class TestProcedure {
public static void main(String[] args) throws Exception{
//驱动标识符
String driver = "oracle.jdbc.OracleDriver";
//url链接
String url = "jdbc:oracle:thin:@localhost:1521:orcl";
//数据库的用户名
String user = "scott";
//数据库的密码
String password = "tiger";
//加载驱动
Class.forName("oracle.jdbc.OracleDriver");
//创建连接
Connection connection = DriverManager.getConnection(url,user,password);
//创建执行引擎
Statement statement = connection.createStatement();
CallableStatement cs = connection.prepareCall("{call pro_demo(?,?)}"); //调用格式 {call 存储过程名(参数,参数)}
cs.setObject(1, 7499);//设置入参值
cs.registerOutParameter(2,Types.VARCHAR);//设置出参类型
cs.execute();//执行
Object objRtn = cs.getObject(2);//获取出参值
System.out.println(objRtn);
//关闭资源
cs.close();
statement.close();
connection.close();
}
}
# TestFunction.java,存储函数测试类
import java.sql.*;
public class TestFunction {
public static void main(String[] args) throws Exception{
//驱动标识符
String driver = "oracle.jdbc.OracleDriver";
//url链接
String url = "jdbc:oracle:thin:@localhost:1521:orcl";
//数据库的用户名
String user = "scott";
//数据库的密码
String password = "tiger";
//加载驱动
Class.forName("oracle.jdbc.OracleDriver");
//创建连接
Connection connection = DriverManager.getConnection(url,user,password);
//创建执行引擎
PreparedStatement ps = connection.prepareStatement("select fun_demo(?) from dual");
//设置入参值
ps.setObject(1, 10);
//执行
ResultSet rs = ps.executeQuery();
if (rs.next()) {
//获取执行结果
System.out.println(rs.getObject(1));
}
ps.close();
connection.close();
}
}
以上就是通过jdbc访问oracle当中的存储过程和存储函数。