JDBC使用executeQuery()调用存储过程出错
问题描述
我已经在Navicat中写好了名为goods_in的存储过程,该存储过程有四个输入参数,一个输出参数。如图:
现在在JDBC中尝试调用该存储过程,但executeQuery()调用存储过程出错,该段代码如下(其中的cst和各变量均已设置好):
String insert = "{call goods_in(?,?,?,?)}";
cst = con.prepareCall(insert);
//设置输入参数
cst.setString(1,name);
cst.setInt(2,num);
cst.setInt(3,price);
cst.setString(4,type);
cst.executeQuery();
cst.close();
错误原因
因为存储过程中包含了一个输出参数,在调用该存储过程的时候需要注册输出参数。
解决方法
将代码改为:
String insert = "{call goods_in(?,?,?,?,?)}";
cst = con.prepareCall(insert);
//设置输入参数
cst.setString(1,name);
cst.setInt(2,num);
cst.setInt(3,price);
cst.setString(4,type);
// 注册输出参数
cst.registerOutParameter(5,Types.INTEGER);
cst.executeQuery();
cst.close();
