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();
经验分享 程序员 微信小程序 职场和发展