加入收藏 | 设为首页 | 会员中心 | 我要投稿 江门站长网 (https://www.0750zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 教程 > 正文

Spring事务管理总结

发布时间:2021-11-15 16:30:38 所属栏目:教程 来源:互联网
导读:事务指的是逻辑上的一组操作,这组操作要么全部成功,要么全部失败 特性: 原子性:指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生 一致性:指事务前后数据的完整性必须保持一致 隔离性:指多个用户并发访问数据库时,一个用户的事务

事务指的是逻辑上的一组操作,这组操作要么全部成功,要么全部失败
 
特性:
 
原子性:指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生
 
一致性:指事务前后数据的完整性必须保持一致
 
隔离性:指多个用户并发访问数据库时,一个用户的事务不能被其他用户的事务所干扰,多个并发事务之间数据要相互隔离
 
持久性:指一个事务一旦被提交,它对数据库中数据的改变是永久性的
 
Spring事务管理高层抽象主要包括3个接口
 
PlatformTramsactionManager(事务管理器)、TransactionDefinition(事务定义信息(隔离、传播、超时、只读))、TransactionStatus(事务具体运行状态)
 
    Spring为不同的持久化框架提供了不同PlatformTramsactionManager接口的实现
 
使用Spring JDBC或iBatis进行持久化数据时使用:org.springframework.jdbc.datasource.DataSourceTransactionManager
 
使用Hibernate3.0版本进行持久化数据时使用:org.springframework.orm.hibernate3.HibernateTransactionManager
 
    事务隔离级别(ISOLATION)
 
DEFAULT:使用后端数据库默认的隔离级别
 
READ_UNCOMMITED:允许你读取还未提交的改变了的数据。可能导致脏、幻、不可重复读
 
READ_COMMITTED:允许在并发事务已经提交后读取,可防止脏读,但幻读和不可重复读仍可发生
 
REPEATABLE_READ:对相同字段的多次读取是一致的,除非数据被事务本身改变。可防止脏、不可重复读,但幻读仍可能发生。
 
SERIALIZABLE:完全服从ACID的隔离级别,确保不发生脏、幻、不可重复读。这在所有的隔离级别中是最慢的,它是典型的通过完全锁定在事务中涉及的数据表来完成的
 
Mysql默认采用REPEATABLE_READ隔离级别
 
Oracle默认采用READ_COMMITTED隔离级别
 
    事务传播行为
 
PROPAGATION_REQUIRED:支持当前事务,如果不存在就新建一个(两个操作在一个事务里)
 
PROPAGATION_REQUIRES_NEW:如果有事务存在,挂起当前事务,创建一个新的事务(两个操作不在一个事务里)
 
PROPAGATION_NESTED:如果当前事务存在,则嵌套事务执行(事务保存点)
 
    Spring支持两种方式事务管理
 
编程式的事务管理:通过TransactionTemplate手动管理事务,实际应用中很少用
 
使用XML配置声明式事务:Spring的声明式事务是通过AOP实现的,开发中推荐使用
 
    *基于TransactionProxyFactoryBean的方式(很少使用)
 
    *基于AspectJ的XML方式(经常使用)
 
        *一旦配置好之后,类上不需要添加任何东西
 
    *基于注解方式(经常使用)
 
        *配置简单。需要在业务层类上添加一个@Transactional的注解

(编辑:江门站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读