qq_张先生 2019-02-22 10:58 采纳率: 57.1%
浏览 767
已采纳

java连接mysql的时候,事务没有提交遇到错误的时候还需要回滚吗?

preparedStatement.executeUpdate();
// int i = 2 / 0;
preparedStatement = connection.prepareStatement(sql2);
preparedStatement.executeUpdate();
connection.commit();

java进行mysql操作的时候,事务没有提交之前遇到错误的时候还需要回滚吗?

  • 写回答

2条回答 默认 最新

  • 真-酸辣土豆丝 2019-02-22 17:39
    关注

    commit()的作用就是提交事物呢到数据库,如果在执行commit之前报错而没有执行commit就分为下面的情况:
    1.不提交只有两种情况:

    客户端进程终止,数据库主动回滚;

    执行代码的进程一直等待,这会阻塞其他修改该数据的会话

    2.提交失败

    只有一种情况吧: 数据库报错,这时数据库给客户端说数据库出问题了,问题修复后应该会主动回滚

    综上,无论因为网络中断还是db服务器问题(磁盘、电源...),都应该主动回滚,否则产生阻塞

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

报告相同问题?

悬赏问题

  • ¥15 帮我调试idea基于spring boot项目
  • ¥15 es 7.17.20版本生成时间戳
  • ¥15 wpf dategrid表头排序图标自定义
  • ¥15 分析下图所示同步时序逻辑电路的逻辑功能。
  • ¥15 halcon联合c#遇到了问题不能解决
  • ¥15 xshell无法连接提示ssh服务器拒绝密码
  • ¥15 AT89C52单片机C语言关于串口通信的位操作
  • ¥20 需要步骤截图(标签-服务器|关键词-map)
  • ¥50 gki vendor hook
  • ¥15 灰狼算法和蚁群算法如何结合