mysql 锁表现象(Lock wait timeout exceeded; try restarting transaction)

这个mysql死锁现象主要是添加、修改或删除的操作添加了事务(添加了@Transactional注解或者是配置文件进行了配置),然后出异常的时候catch捕获了,导致事务没有收到异常一直在等待着,没有结束,也不会触发回滚操作,所以导致表被锁。代码里面解决的办法是在catch那里把异常给抛出来,如:

}catch(Exception e){
   e.printStackTrace();
   throw new RuntimeException(e);
  }

throw new RuntimeException(e); 就是把异常给抛出来,让事务能触发回滚,释放表的锁资源。。或者直接throw e 也可以,如:

throw e

参考资料:https://www.cnblogs.com/menglong1108/p/11919273.html

但是如果很急需要马上解决的话,可以查询是哪个连接,然后杀掉(kill)它,这样也可以释放锁资源;

具体参考:https://blog.csdn.net/java__project/article/details/100137526

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值