关于Spring事务<tx:annotation-driven/>的理解
来源:互联网 发布:数控车图纸及编程 编辑:程序博客网 时间:2024/05/21 06:29
在使用Spring MVC时,配置文件中经常看到annotation-driven的注解,其含义是支持注解,一般根据前缀tx、mvc等来理解其作用。
<tx:annotation-driven/>就是支持事务注解的(@Transactional)、<mvc:annotation-driven/>就是支持mvc的注解的。
<tx:annotation-driven/>会有一个属性来指定使用哪个事务管理器,如:<tx:annotation-driven transaction-manager="transactionManager" />。然后事务管理器transactionManager会引用dataSource(JPA、hibernate、mybatis等)。
此配置属于声明式事务管理,声明式事务管理是建立在AOP之上的,其本质是对方法前后进行拦截,然后在目标方法开始之前创建或者加入一个事务,在执行完目标方法之后根据执行情况提交或者回滚事务。(声明式事务最大优点)不需要通过编程的方式管理事务,这样就不需要在业务逻辑代码中掺杂事务管理代码,只需要在配置文件中做相关的事务规则说明(或通过基于@Transactional注解的方式),就可以将事务规则应用到业务逻辑中。非侵入式的开发方式,声明式事务管理使业务代码不受污染,一个普通的POJO对象,只要加上注解就可以获得完全的事务支持。声明式事务唯一不足就是其最细粒度只能作用到方法级别。
Spring事务特性:
Spring所有的事务管理策略类都继承自org.springframework.transaction.PlatformTransactionManager接口。
public interface PlatformTransactionManager { TransactionStatus getTransaction(TransactionDefinition definition) throws TransactionException; void commit(TransactionStatus status) throws TransactionException; void rollback(TransactionStatus status) throws TransactionException;}其中TransactionDefinition接口定义以下特性:
事务隔离级别
隔离级别是指若干个并发的事务之间的隔离程度。TransactionDefinition 接口中定义了五个表示隔离级别的常量:
- TransactionDefinition.ISOLATION_DEFAULT:这是默认值,表示使用底层数据库的默认隔离级别。对大部分数据库而言,通常这值就是TransactionDefinition.ISOLATION_READ_COMMITTED。
- TransactionDefinition.ISOLATION_READ_UNCOMMITTED:该隔离级别表示一个事务可以读取另一个事务修改但还没有提交的数据。该级别不能防止脏读,不可重复读和幻读,因此很少使用该隔离级别。比如PostgreSQL实际上并没有此级别。
- TransactionDefinition.ISOLATION_READ_COMMITTED:该隔离级别表示一个事务只能读取另一个事务已经提交的数据。该级别可以防止脏读,这也是大多数情况下的推荐值。
- TransactionDefinition.ISOLATION_REPEATABLE_READ:该隔离级别表示一个事务在整个过程中可以多次重复执行某个查询,并且每次返回的记录都相同。该级别可以防止脏读和不可重复读。
- TransactionDefinition.ISOLATION_SERIALIZABLE:所有的事务依次逐个执行,这样事务之间就完全不可能产生干扰,也就是说,该级别可以防止脏读、不可重复读以及幻读。但是这将严重影响程序的性能。通常情况下也不会用到该级别。
所谓事务的传播行为是指,如果在开始当前事务之前,一个事务上下文已经存在,此时有若干选项可以指定一个事务性方法的执行行为。在TransactionDefinition定义中包括了如下几个表示传播行为的常量:
- TransactionDefinition.PROPAGATION_REQUIRED:如果当前存在事务,则加入该事务;如果当前没有事务,则创建一个新的事务。这是默认值。
- TransactionDefinition.PROPAGATION_REQUIRES_NEW:创建一个新的事务,如果当前存在事务,则把当前事务挂起。
- TransactionDefinition.PROPAGATION_SUPPORTS:如果当前存在事务,则加入该事务;如果当前没有事务,则以非事务的方式继续运行。
- TransactionDefinition.PROPAGATION_NOT_SUPPORTED:以非事务方式运行,如果当前存在事务,则把当前事务挂起。
- TransactionDefinition.PROPAGATION_NEVER:以非事务方式运行,如果当前存在事务,则抛出异常。
- TransactionDefinition.PROPAGATION_MANDATORY:如果当前存在事务,则加入该事务;如果当前没有事务,则抛出异常。
- TransactionDefinition.PROPAGATION_NESTED:如果当前存在事务,则创建一个事务作为当前事务的嵌套事务来运行;如果当前没有事务,则该取值等价于TransactionDefinition.PROPAGATION_REQUIRED。
所谓事务超时,就是指一个事务所允许执行的最长时间,如果超过该时间限制但事务还没有完成,则自动回滚事务。在 TransactionDefinition 中以 int 的值来表示超时时间,其单位是秒。
默认设置为底层事务系统的超时值,如果底层数据库事务系统没有设置超时值,那么就是none,没有超时限制。
事务只读属性
Spring事务回滚规则
指示Spring事务管理器回滚一个事务的推荐方法是当前事务的上下文内抛出异常。Spring事务管理器会捕捉任何未处理的异常,然后依据规则决定是否回滚抛出异常的事务。
- 关于Spring事务<tx:annotation-driven/>的理解。
- 关于Spring事务<tx:annotation-driven/>的理解
- 关于Spring事务<tx:annotation-driven/>的理解(Controller可以使用@Transactional)
- 关于Spring事务<tx:annotation-driven/>的理解(Controller可以使用@Transactional)
- 关于Spring事务<tx:annotation-driven/>的理解(Controller可以使用@Transactional)
- 关于Spring事务<tx:annotation-driven/>的理解(Controller可以使用@Transactional)
- spring配置事务 元素 "tx:annotation-driven" 的前缀 "tx" 未绑定
- spring 事务 @Transactional注解参数 tx:annotation-driven
- spring 事务 @Transactional注解参数 tx:annotation-driven
- spring 事务 @Transactional注解参数 tx:annotation-driven
- spring中的<tx:annotation-driven>
- 关于spring配置中the prefix "tx" for element "tx:annotation-driven" is not bound 问题的处理
- <tx :annotation-driven> <mvc: annotation-driven >注解理解
- spring事务的annotation-driven用法
- spring的annotation-driven配置事务管理器
- 解决 spring mvc 3.0 结合 hibernate3.2 使用<tx:annotation-driven>声明式事务无法提交的问题
- 解决 spring mvc 3.0 结合 hibernate3.2 使用<tx:annotation-driven>声明式事务无法提交的问题
- 解决 spring mvc 3.0 结合 hibernate3.2 使用<tx:annotation-driven>声明式事务无法提交的问题
- 自定义view点击产生涟漪
- 支持向量机(预测)
- java反射技术
- python笔记--List合并方法
- Spring思维导图,让spring不再难懂(一)
- 关于Spring事务<tx:annotation-driven/>的理解
- SpringMvc RequestMapping路径可配置
- 微信网页授权获取头像昵称,不弹出授权页面
- Java执行源码编译
- WMS GetFeatureInfo (Tile Layer)——WMS获取要素信息(瓦片图层)
- 1、H5标签 音效audio
- hdu 2446 Shell Pyramid
- JS与后台的交互一些笔记
- android sqlite清空表数据