java.sql.SQLException: Could not retrieve transaction read-only status from server

以下是本人踩过的坑,忘各位博友引以为戒(主要是对事物的了解太浅,下面会总结出来少许的理解)

一、异常:

内容:下载图片大概用了二十多分钟,然后去更新数据库直接数据库连接断开!

原因:事物等待超时

解决:

我这里就一个更新语句,所以直接把@Transactional去掉问题解决(更新的数据量多,并且数据比较复杂的时候不建议这样做)

 

下面是自己对spring中事物的一点测试:

第一种情况:

第二种情况:

第三种情况:

第四种情况(有异步):

第五种情况(有异步):

第六中情况:

第七种情况:

第八种情况:

总结(springAOP中的事物):

(同一个service主方法衍生的子方法):只对首次调用的方法上面的@Transactional有效有效,子方法上添加spring的异步方法同带事物都不会生效;

(两个service的方法互调):两个service都有事物,主方法会生效,子方法不生效;service1(主方法)有事物,service2(子方法)没事物,此时两个service共用主方法的事物;service1(主方法)没事物,service2(子方法)有事物,此时只用子方法的事物会生效,主方法不存在事物;

/****************************************************谢谢惠顾*****************************************************/

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值