oracle的高阶使用【6】jdbc访问oracle存储过程和存储函数

本文介绍了如何通过jdbc在Java项目中访问Oracle数据库的存储过程和存储函数。首先确保Oracle环境和scott用户准备就绪,接着在IDEA中创建项目并引入Oracle驱动,然后在sqldeveloper中定义存储过程和函数,最后在测试类中实现调用操作。

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

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

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值