06 jdbc访问oracle存储过程和存储函数

在学习了存储过程和存储函数以后,本文将阐述通过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当中的存储过程和存储函数。

你可能感兴趣的:(06 jdbc访问oracle存储过程和存储函数)