spring事务配置总结

第一种:使用注解(推荐)
<!-- 第一步 配置事务管理器 -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
  <!--注入sessionFactory-->
  <property name="sessionFactory" ref="sessionFactory"></property>
</bean>
<!-- 第二步 开启事务注解 -->
<tx:annotation-driven transaction-manager="transactionManager"/>

业务层
@Transactional(isolation=Isolation.READ_COMMITTED,propagation=Propagation.REQUIRED,rollbackFor=Exception.class,readOnly=false)
public class UserServer{

  public void insert(){}

  public void delete(){}

  public void update(){}

  @Transactional(propagation=Propagation.SUPPORTS)
  public User selectById(){}
}

第二种:纯xml配置
<!-- 第一步 配置事务管理器 -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
  <!-- 注入dataSource -->
  <property name="dataSource" ref="dataSource"></property>
</bean>

<!-- 第二步 配置事务增强 -->
<tx:advice id="txadvice" transaction-manager="transactionManager">
  <!-- 做事务操作 -->
  <tx:attributes>
    <!-- 设置进行事务操作的方法匹配规则 -->
    <tx:method name="select*" propagation="SUPPORTS" read-only="true"/>
    <tx:method name="*" propagation="REQUIRED" isolation="READ_COMMITTED" read-only="false" rollback-for="Exception"/>
  </tx:attributes>
</tx:advice>

<!-- 第三步 配置切面 -->
<aop:config>
  <!-- 切入点 -->
  <aop:pointcut expression="execution(* com.lvzhl.*.*(..))" id="pc"/>
  <!-- 切面 -->
  <aop:advisor advice-ref="txadvice" pointcut-ref="pc"/>
</aop:config>

------------------------------------------------------------------

事务属性:

1>隔离级别isolation:
  READ_UNCOMMITTED:读未提交,事务之间可以读取到对方未提交的数据,会导致【脏读,不可重复读,幻影读】
  READ_COMMITTED:读提交,事务之间只可以读取到对方已提交的数据,可以防止【脏读】【建议使用】
  REPEATABLE_READ:可重复读,一个事务多次读取同一条数据,结果一致,可以防止【脏读,不可重复读】
  SERIALIZABLE:序列化读,多个事务串行发生,可以防止一切非法的读取。
  *注意:隔离级别逐渐提高,并发性越来越差,但安全性越来越好。
  *非法的读取状态:
    1. 脏读:事务读取到了其他事务未提交的数据(重点记忆)
    2. 不可重复读:一个事务中多次读取同一条数据,但结果不一致。
    3. 幻影读:一个事务中多次读取同一张表,表的行数不一致。
  *在oracle中只支持 读提交和序列化读 且默认为 【读提交】

2>传播性propagation:防止事务嵌套。ServiceA的方法中调用了 ServiceB中方法。
  supports: 如果当前已有事务环境,则融入,否则在非事务环境下执行。适合查询业务
  required: 如果当前已有事务环境,则融入,否则新启动一个事务,在事务中运行。适合增删改业务
3>读写性readOnly:
  true:只读事务,适合查询业务,在事务中只允许查询操作
  fasle:读写事务,适合增删改业务,事务中允许查询和改动(默认)
4>回滚性rollback-for:
  在业务中抛出RuntimeException异常时自动回滚。
  在业务中抛出Exception异常时依然提交(默认)。

----------------------------------------------------------------------------

事务的概念:

事务是数据库保证数据完整性的一种机制,是数据库操作的最小单元,包括一条或者多条sql语句。在同一个事务的多条sql语句执行的过程中,要么同时成功,事务成功(事务提交:commit);如果有一条sql语句执行失败,整个事务失败,事务回滚(rollback)。

事务的开始:

  同一个事务中的多条sql中的第一条sql执行开始

事务结束:

  commit

  rollback

事务的特点:ACID(面试概念)

Atomicity:原子性,同一个事务中的多条sql不可分割。

Consistency:一致性,事务在操作前后的状态一致。

Isolation:隔离性,事务之间相互独立,没有影响。

Durability:持久性,事务的操作是持久化数据库

时间: 2024-11-13 14:48:26

spring事务配置总结的相关文章

Spring事务配置的五种方式

Spring事务配置的五种方式 前段时间对Spring的事务配置做了比较深入的研究,在此之间对Spring的事务配置虽说也配置过,但是一直没有一个清楚的认识.通过这次的学习发觉Spring的事务配置只要把思路理清,还是比较好掌握的. 总结如下: Spring配置文件中关于事务配置总是由三个组成部分,分别是DataSource.TransactionManager和代理机制这三部分,无论哪种配置方式,一般变化的只是代理机制这部分. DataSource.TransactionManager这两部分

spring事务配置

前几天被问到,如何防止服务器宕机,造成的数据操作的不完全. 问了一下同事,是事务.哎,恍然大悟,迷糊一时了. 声明式的事务配置,这个是最推荐的,配置到service层. <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:context="http://www.sp

Spring事务配置的五种方式和spring里面事务的传播属性和事务隔离级别

转: http://blog.csdn.net/it_man/article/details/5074371 Spring事务配置的五种方式 前段时间对Spring的事务配置做了比较深入的研究,在此之间对Spring的事务配置虽说也配置过,但是一直没有一个清楚的认识.通过这次的学习发觉Spring的事务配置只要把思路理清,还是比较好掌握的. 总结如下: Spring配置文件中关于事务配置总是由三个组成部分,分别是DataSource.TransactionManager和代理机制这三部分,无论哪

Spring事务配置的五种方式(转)

Spring事务配置的五种方式 前段时间对Spring的事务配置做了比较深入的研究,在此之间对Spring的事务配置虽说也配置过,但是一直没有一个清楚的认识.通过这次的学习发觉Spring的事务配置只要把思路理清,还是比较好掌握的. 总结如下: Spring配置文件中关于事务配置总是由三个组成部分,分别是DataSource.TransactionManager和代理机制这三部分,无论哪种配置方式,一般变化的只是代理机制这部分. DataSource.TransactionManager这两部分

【转】 Spring事务配置的五种方式和spring里面事务的传播属性和事务隔离级别

spring事务配置的五种方式 前段时间对Spring的事务配置做了比较深入的研究,在此之间对Spring的事务配置虽说也配置过,但是一直没有一个清楚的认识.通过这次的学习发觉Spring的事务配置只要把思路理清,还是比较好掌握的. 总结如下: Spring配置文件中关于事务配置总是由三个组成部分,分别是DataSource.TransactionManager和代理机制这三部分,无论哪种配置方式,一般变化的只是代理机制这部分. DataSource.TransactionManager这两部分

记一次 Spring 事务配置踩坑记

记一次 Spring 事务配置踩坑记 问题描述:(SpringBoot + MyBatisPlus) 业务逻辑伪代码如下.理论上,插入数据 t1 后,xxService.getXxx() 方法的查询条件会不满足,会查询不到数据.结果事与愿违,后一次的查询,居然查到了数据. void saveXxx(){  xxService.getXxx(); // 查到一条数据 data1  xxService.insert(); // 插入一条数据 t1  xxService.getXxx(); // 查到

spring事务配置的坑

基于 <tx> 命名空间的声明式事务管理 前面两种声明式事务配置方式奠定了 Spring 声明式事务管理的基石.在此基础上,Spring 2.x 引入了 <tx> 命名空间,结合使用 <aop> 命名空间,带给开发人员配置声明式事务的全新体验,配置变得更加简单和灵活.另外,得益于 <aop> 命名空间的切点表达式支持,声明式事务也变得更加强大. 1.如果没有配置事务,数据库操作是无法成功的. 2. 如果用try catch里的操作是无法用事务管理的? Spr

spring事务配置详解

spring的事务配置一直感觉都比较的模糊,没有一个清楚的认识.通过这次的学习发觉Spring的事务配置只要把思路理清,还是比较好掌握的. 总结如下: Spring配置文件中关于事务配置总是由三个组成部分,分别是DataSource.TransactionManager和代理机制这三部分,无论哪种配置方式,一般变化的只是代理机制这部分. DataSource.TransactionManager这两部分只是会根据数据访问方式有所变化.但总的来说都是对Connection的封装,变化基本上可以忽略

SSH深度历险(六) 深入浅出----- Spring事务配置的五种方式

这对时间在学习SSH中Spring架构,Spring的事务配置做了具体总结.在此之间对Spring的事务配置仅仅是停留在听说的阶段,总结一下.总体把控.通过这次的学习发觉Spring的事务配置仅仅要把思路理清,还是比較好掌握的. 总结例如以下: Spring配置文件里关于事务配置总是由三个组成部分,各自是DataSource.TransactionManager和代理机制这三部分.不管哪种配置方式.一般变化的仅仅是代理机制这部分. DataSource.TransactionManager这两部

spring 事务配置

事务配置文档xml <!-- from the file 'context.xml' --> <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" x