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

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 软件供应链安全是跟可靠性有关还是跟安全性有关?
  • ¥15 电脑蓝屏logfilessrtsrttrail问题
  • ¥20 关于wordpress建站遇到的问题!(语言-php)(相关搜索:云服务器)
  • ¥15 【求职】怎么找到一个周围人素质都很高不会欺负他人,并且未来月薪能够达到一万以上(技术岗)的工作?希望可以收到写有具体,可靠,已经实践过了的路径的回答?
  • ¥15 Java+vue部署版本反编译
  • ¥100 对反编译和ai熟悉的开发者。
  • ¥15 带序列特征的多输出预测模型
  • ¥15 Python 如何安装 distutils模块
  • ¥15 关于#网络#的问题:网络是从楼上引一根网线下来,接了2台傻瓜交换机,也更换了ip还是不行
  • ¥15 资源泄露软件闪退怎么解决?