事务
事务:是指逻辑上的一组操作,这组操作要么全部成功,要么全部失败。
事务的特性:
- 原子性:原子性是指事务是一个不可 分割的工作单位,事务中的操作要么都发生,要么都不发生。
- 一致性:一致性是指事务前后数据的完整性必须保持一致
- 隔离型:是指多个用户并发访问数据库时,一个用户的事务不能被其他用户的事务所干扰,多个并发事务直接数据要相互隔离
- 持久性:是指一个事务一旦被提交,它对数据库中数据的改变是永久性的,即使数据库发生故障也不应该对其有任何影响
Spring支持两种方式事务管理:
1.编程式事务管理
- 在实际应用中很少使用
- 通过TransactionTemplate手动管理事务
2.使用XML配置声明式事务
- 开发中推荐使用(代码入侵性最小)
- Spring的声明式事务是通过AOP实现的
- 基于TransactionProxyFactoryBean的方式.(很少使用)
需要为每个进行事务管理的类,配置一个TransactionProxyFactoryBean进行增强.
- 基于AspectJ的XML方式.(经常使用)
一旦配置好之后,类上不需要添加任何东西
- 基于注解方式.(经常使用)
配置简单,需要在业务层上添加一个@Transactional的注解.
事务的API接口介绍
- Platform TransactionManager(事务管理器)
Spring为不同的持久化框架提供不同的Platform TransactionManager接口实现
- TransactionDefinition(事务定义信息(隔离、传播、超时、只读))
TransactionDefinition事务定义信息:定义隔离信息
脏读:一个事务读取了另一个事务改写但还未提交的数据,如果这些数据被回滚,则读到的数据是无效的
不可重复读:在同一个事务中,多次读取同一数据返回的结果有所不同
幻读:一个事务读取了几行记录后,另一个事务插入一些记录,幻读就发生了。再后来的查询中,第一个事务就会发现有些 原来没有的记录
事务的隔离级别:
MySQL默认采用REPEATABLE _READ隔离级别
Oracle默认采用READ_COMMITTED隔离级
TransactionDefinition事务定义信息:定义事务的传播行为
重点记标红的,标红的是比较常用的。
- TransactionStatus(事务具体运行状态)
用来记录事务的状态 ,该接口定义了一组方法,用来获取或判断事务的相应状态信息。
平台事务管理器(PlatformTransactionManager)会根据TransactionDefinition中定义的事务信息(包括隔离级别、传播行为)来进行事务的管理,在管理的过程中事务可能产生了保存点或事务是新的事务等情况,那么这些信息都会记录在TransactionStatus的对象中。