事务是逻辑上的一组操作,要么都执行,要么都不执行。
事务的四大特性
-
原子性(Atomicity):一个原子事务要么完整执行,要么不执行。
由undolog日志来保证,记录需要回滚的日志信息,事务回滚时撤销已经执行成功的sql。
-
一致性(Consistency):底层数据存储的完整性,业务逻辑上的一致性。
由其他三大特性来保证,程序代码要保证业务上的一致性。
-
隔离性(Isolation):事务在不干扰其他进程或事务的前提下独立进行。
由MVCC来保证。
-
持久性(Durability):在事务的执行过程中,对数据所作的所有改动必须在事务成功结束前保存至物理存储设备。
由redolog来保证,mysql修改数据的时候会在redolog中记录一份日志数据,就算数据没有保存成功,只要日志数据保存成功了,数据仍然不会丢失。
并发事务带来的问题
- 脏读(Dirty read):一个事务读到修改之前的数据
- 丢失修改(Lost to modify)
- 不可重复读(Unrepeatable):两次读到的数据不同
- 幻读(Phantom read):第二次读到的数据多了记录
@Transactional注解
声明式事务管理建立在AOP之上的。其本质是对方法前后进行拦截,然后在目标方法开始之前创建或者加入一个事务,在执行完目标方法之后根据执行情况提交或者回滚事务。
常用属性
- propagation 可选的事务传播行为设置
- isolation 可选的事务隔离级别设置
- timeout 事务超时时间设置
- rollbackFor 导致事务回滚的异常类数组