java代码 调用 存储过程

第一步,在pl/sql中写一个 存储过程:

create or replace procedure empid_name_address(
       p_empid in t_emp.empid%type, --输入型参数
       p_empname out t_emp.empname%type,--输出型参数
       p_empaddress out t_emp.empadress%type
)
as      
begin
  select empname,empadress into p_empname,p_empaddress from t_emp where t_emp.empid = p_empid;
end;

第二步:写java 代码:

import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.DriverManager;s
import java.sql.SQLException;

import oracle.jdbc.OracleTypes;

public class JdbcTest {
    private final static String USERNAME = "szq";
    private final static String PASSWORD = "szq";
    private final static String URL = "jdbc:Oracle:thin:@localhost:1521:orcl";
    private final static String DRIVER = "oracle.jdbc.driver.OracleDriver";

    public static void main(String[] arg0){
        testProcedual();
    }
    public static void testProcedual(){
        Connection conn = null;
        //定义调用存储过程的对象
        CallableStatement call = null;
        try {
            Class.forName(DRIVER);
            conn = DriverManager.getConnection(URL, USERNAME, PASSWORD);

            call = conn.prepareCall("{call empid_name_address(?,?,?)}");
            //为输入型参数设值
            call.setString(1, "11104");
            //注册输出型参数
            call.registerOutParameter(2, OracleTypes.VARCHAR);
            call.registerOutParameter(3, OracleTypes.VARCHAR);
            //执行存储过程
            call.execute();
            //获取返回值
            String name = call.getString(2);
            String address = call.getString(3);
            System.out.println("11104员工的姓名是"+name+",该员工的住址是"+address);
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } catch (SQLException e) {
            e.printStackTrace();
        }

        return conn; 
    }

}

输出的结果为:
11104员工的姓名是肖小军,该员工的住址是河南

java中的代码注意几点:
1.对于输出型的参数,一定要注册,否则会默认为输入型参数。
2.注册时括号中的 OracleTypes 后面有“s”,不要丢了。

  • 4
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值