@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的事物也不会生效,不会出现回滚现象。

你可能感兴趣的:(java相关)