qq_46604486 2021-11-23 17:04 采纳率: 33.3%
浏览 53
已结题

数据更新不成功,感觉在是sql语句问题,求帮助

问题遇到的现象和发生背景

在JDBC的使用里,我的数据需要更新,确不成功

问题相关代码,请勿粘贴截图
public static void changeOtherAccount() {
     ResultSet rs;
     PreparedStatement preSql;
     Connection con3=new DBconn().getConn();
     String sql="update user set name=?,password=? where account=?";
     try {
         String account=ChangeAccountMessage.accounttext.getText();
         
         String name=ChangeAccountMessage.nametext.getText();
     
         String password=new String(ChangeAccountMessage.passwordtext.getPassword());
         
        preSql=con3.prepareStatement(sql);
        preSql.setString(1,name);
        preSql.setString(2,password);
        preSql.setString(3,account);
        boolean ok=preSql.execute(sql);
        
        System.out.println(ok);
    } catch (SQLException e) {
        System.out.println(e);
    }
 }
运行结果及报错内容

com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '?,password=? where account=?' at line 1

我的解答思路和尝试过的方法

暂时没有

我想要达到的结果

数据更新成功

  • 写回答

4条回答 默认 最新

  • Vae 东 2021-11-24 10:52
    关注

    没用过你这个mysql写法.但是看SQL语句的那个?号值是没赋上.preSql是设置值.然后preSql.excuteUpdate(Sql),这里是不是不对劲
    现在的报错语句是这样的

    img

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

报告相同问题?

问题事件

  • 系统已结题 12月2日
  • 已采纳回答 11月24日
  • 创建了问题 11月23日

悬赏问题

  • ¥15 使用ue5插件narrative时如何切换关卡也保存叙事任务记录
  • ¥20 软件测试决策法疑问求解答
  • ¥15 win11 23H2删除推荐的项目,支持注册表等
  • ¥15 matlab 用yalmip搭建模型,cplex求解,线性化处理的方法
  • ¥15 qt6.6.3 基于百度云的语音识别 不会改
  • ¥15 关于#目标检测#的问题:大概就是类似后台自动检测某下架商品的库存,在他监测到该商品上架并且可以购买的瞬间点击立即购买下单
  • ¥15 神经网络怎么把隐含层变量融合到损失函数中?
  • ¥15 lingo18勾选global solver求解使用的算法
  • ¥15 全部备份安卓app数据包括密码,可以复制到另一手机上运行
  • ¥20 测距传感器数据手册i2c