@Transactional可以添加在方法上
添加在方法上时,表示该方法出现了异常或者报错,而导致之前数据库没有进行回滚事件,也就是说如果在方法中,有报错,但是添加了@Transactional 则会开始回滚。
@Transactional 在异常被捕获的情况下,不会进⾏事务⾃动回滚,但是可以手动添加TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); 进行回滚操作
Spring中的事务隔离级别:
可以通过 @Transactional 中的 isolation 属性进⾏设置
直接在@Transactional()//直接在括号中填写即可
1. Isolation.DEFAULT:以连接的数据库的事务隔离级别为主
2. Isolation.READ_UNCOMMITTED:读未提交,可以读取到未提交的事务,但存在脏读
3. Isolation.READ_COMMITTED:读已提交,只能读取到已经提交的事务,解决了脏读的问题,但是存在不可重复读的问题
4. Isolation.REPEATABLE_READ:可重复读,解决了不可重复读的问题,但存在幻读问题(MySQL默认级别)
5. Isolation.SERIALIZABLE:串⾏化,可以解决所有并发问题,但性能太低,一般很少使用
Spring 事务传播机制:
事务传播可以分为三个方面:
@Transactional(propagation = Propagation.REQUIRED)//默认的
当我使用这个事务的传播机制添加数据库操作是,代码不小心出现了异常,控制台显示了添加成功,但是不会添加到数据库中
@Transactional(propagation = Propagation.NESTED)
使用 try catch捕获异常,发现出了异常,但是只是当前执行的事务回滚,添加的事务不回滚,数据库还是添加了数据。(例如就是你有一家店铺,你在店铺里面做生意,生意垮掉了,但是店铺还是存在的)