cantiaozi 2017-04-24 05:49 采纳率: 50%
浏览 1081
已采纳

java连接到mysql数据库问题,求教!

在名为chapter06的数据库中成功创建了一个存储过程,代码如下:
create procedure addcount (out count int)
begin
declare itmp int;
declare cur_id cursor for select id from stu;
declare exit handler for not found close cur_id;
select count(*) into count from stu;
set @sum =0;
open cur_id;
repeat
fetch cur_id into itmp;
if itmp <10
then set @sum = @sum +itmp;
end if;
until 0 end repeat;
close cur_id;
end //

然后编写了一个Java程序,连接到chapter06,执行存储过程,代码如下:

import java.sql.*;
public class TestProc {

public static void main(String[] args) {
    try {
        Class.forName("com.mysql.jdbc.Driver");
        Connection cnn = DriverManager.getConnection("jdbc:mysql://localhost/chapter06?user=root&password");
        CallableStatement cs = cnn.prepareCall("{call addcount(?)");
        cs.registerOutParameter(1, Types.INTEGER);
        cs.execute();
        System.out.println(cs.getInt(1));
    } catch (Exception e) {
        e.printStackTrace();
    }

}

}

执行该程序,命令行窗口提示java.sql.SQLException: Parameter number 1 is not an OUT parameter,请问怎么回事?

展开全部

  • 写回答

6条回答 默认 最新

  • engchina 2017-04-24 16:41
    关注

    漏掉了一个 }

    修改前
    CallableStatement cs = cnn.prepareCall("{call addcount(?)");
    修改后
    CallableStatement cs = cnn.prepareCall("{call addcount(?)}");

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(5条)
编辑
预览

报告相同问题?

悬赏问题

  • ¥15 代写uni代码,app唤醒
  • ¥15 全志t113i启动qt应用程序提示internal error
  • ¥15 ensp可以看看嘛.
  • ¥80 51单片机C语言代码解决单片机为AT89C52是清翔单片机
  • ¥60 优博讯DT50高通安卓11系统刷完机自动进去fastboot模式
  • ¥15 minist数字识别
  • ¥15 在安装gym库的pygame时遇到问题,不知道如何解决
  • ¥20 uniapp中的webview 使用的是本地的vue页面,在模拟器上显示无法打开
  • ¥15 网上下载的3DMAX模型,不显示贴图怎么办
  • ¥15 关于#stm32#的问题:寻找一块开发版,作为智能化割草机的控制模块和树莓派主板相连,要求:最低可控制 3 个电机(两个驱动电机,1 个割草电机),其次可以与树莓派主板相连电机照片如下:
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部