@Transactional 的使用

事物:隔离级别(并发事物) 传播行为(事物上下文)
**–**插入,仅仅 一个表的数据–其他默认,传播行为:propagation = Propagation.REQUIRES_NEW

**–**仅仅是查询,无论查几张表 ,其他默认(事物还是有,只不过仅仅读取,不允许更新操作),readOnly=true

**–**对于checked这种例外,默认情况下它是不会进行事务回滚的,但是如果我们需要它进行事务回滚,这时候可以在delete方法上通过@Transaction这个注解来修改它的行为。
@Transactional(rollbackFor=Exception.class)
rollbackFor这属性指定了,既使你出现了checked这种例外,那么它也会对事务进行回滚

**–**对于仅仅是读取的方法可以不开启事物,可以采用propagation这个事务属性@Transactional(propagation=Propagation.NOT_SUPPORTED)
,propagation这个属性指定了事务传播行为,我们可以指定它不支持事务,当我们这么写了之后,Spring容器在getPersons方法执行前就不会开启事务.

**–**伪回滚
@Transactional(propagation = Propagation.REQUIRED)
public void test() {
//…
}
上面的设置的作用是:当方法test出现 “运行时异常” 时,会进行事务回滚(其实是伪回滚,只是把之前的操作改回去。
比如有插入操作且是主键是自增长的,假设插入一条记录的操作前,下一id的值是1,但伪回滚后,就变成2了,也就是说,下一次成功插入后,id的值是2而不是1)。
但是如果,在test方法的方法体中捕获了异常,则不会对事务进行回滚,代码如下:
@Transactional
public void test() {
try{
//…
} catch(DataAccessException e) {
e.printStackTrace();
}
}
要想既捕获异常然后做一些操作,又想对失败的操作进行回滚,可以在捕获异常后,再对异常抛出,即让spring能捕获该异常 ,示例如下:
@Transactional
public void test() {
try{
//…
} catch(DataAccessException e) {
e.printStackTrace();
throw e;
}
}

/orderInternal/payCallback

**–**同一个类内,方法间调用,事物失效
原因:仅有在公有方法上标记的@Transactional有效;仅有外部方法调用过程才会被代理截获,事务才会有效,也就是说,一个方法调用本对象的另一个方法,没有通过代理类,事务也就无法生效。
例子:A,B两个方法,A方法没有事物,B方法有事物,那么A方法调用B,中间有异常出现,B的事物也不会生效,不会出现回滚现象。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值