spring 事务处理

1. 事务处理简介

事务是一个业务,是一个不可分割的逻辑工作单元,具备ACID特性,实际工作中可借助Spring进行事务管理。
spring的事务模块是通过AOP来实现的。Spring提供了两种事务管理方式, 编程式事务和声明式事务。编程式事务指的是通过编码方式实现事务;声明式事务基于 AOP,将具体业务逻辑与事务处理解耦。声明式事务管理使业务代码逻辑不受污染, 因此在实际使用中声明式事务用的比较多。

2. 事务的四大特性

2.1 原子性

事务中的所有操作、所有SQL语句是一个整体,要么全都执行成功,要么全都执行失败。

2.2 一致性

事务前后的业务数据之和是保持不变的。例如存钱操作,存之前和存之后的总钱数应该是一致的。

2.3 隔离性

事务与事务是相互隔离的,在隔离级别足够高的情况下,事务和事务之间是完全隔离开来的。一个事务是看不到另外一个事物正在进行中的操作。要么看到另一个事物开始之前的状态, 要么看到事务结束之后的状态。

2.4 持久性

持久性是指在事物提交后, 对数据的修改将会是永久的。

3. 声明式事务管理实现

Spring中声明式事务处理有两种方式,一种是在配置文件中做相关的事务规则声明,另一种是基于@Transactional 注解的方式。

笔者喜欢用注解方式方式实现:

在类或方法上使用@Transactional注解告诉spring框架要在这个类或者这个方法执行时要添加事务控制。当 @Transactional 放在类上时,说明所有该类的公共方法都配置相同的事务属性信息。当 @Transactional 放在类上也放在方法上时,应用程序会以方法级别的事务属性信息来管理事务。
@Transactional注解的属性:
● timeout 事务的超时时间,默认值为-1,表示没有超时显示。如果配置了具体时间,则超过该时间限制但事务还没有完成,则自动回滚事务。
● read-only指定事务是否为只读事务,默认值为 false;为了忽略那些不需要事务的方法,比如读取数据,可以设置 read-only 为 true。
● rollback-for 用于指定能够触发事务回滚的异常类型,如果有多个异常类型需要指定,各类型之间可以通过逗号分隔。
● no-rollback- for 抛出 no-rollback-for 指定的异常类型,不回滚事务。
● isolation事务的隔离度,默认值采用 DEFAULT。

4. 事务传播特性

事务传播(Propagation)特性指不同业务(service)对象中的事务方法之间相互调用时,事务的传播方式。
● Propagation.REQUIRED 如果没有事务创建新事务,如果当前有事务参与当前事务。
● Propagation.REQUIRES_NEW 必须是新事务, 如果有当前事务, 挂起当前事务并且开启新事务。
● Propagation.SUPPORTS 支持当前事务,如果当前没有事务,就以非事务方式执行。
● Propagation.NOT_SUPPORTED 以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。
● Propagation.NEVER 以非事务方式执行,如果当前存在事务,则抛出异常。
● Propagation.MANDATORY 使用当前的事务,如果当前没有事务,就抛出异常。
● Propagation.NESTED 如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则执行Propagation.REQUIRED类似的操作。

5. spring事务隔离级别

● ISOLATION_DEFAULT 这是一个PlatfromTransactionManager默认的隔离级别,使用数据库默认的事务隔离级别。
● ISOLATION_READ_UNCOMMITTED(读未提交数据)安全级别最低, 可能出现任何事务并发问题(比如脏读、不可以重复读、幻读等),性能最好,但是不建议用。
● ISOLATION_READ_COMMITTED(读已提交数据)防止脏读,没有处理不可重复读,也没有处理幻读;
性能比REPEATABLE READ好,Oracle数据库默认的隔离级别。
● ISOLATION_REPEATABLE_READ (可重复读) 防止脏读和不可重复读,不能处理幻读问题;
性能比SERIALIZABLE好。MySQL数据库默认的隔离级别。
● ISOLATION_SERIALIZABLE(序列化)不会出现任何并发问题,因为它是对同一数据的访问是串行的,非并发访问的,性能最差。

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值