springboot本地事务

简介: springboot本地事务

1、事务的基本性质

数据库事务的几个特性:原子性(Atomicity )、一致性( Consistency )、隔离性或独立性( Isolation)和持久性(Durabilily),简称就是 ACID;

 原子性:一系列的操作整体不可拆分,要么同时成功,要么同时失败

 一致性:数据在事务的前后,业务整体一致。

       转账。A:1000;B:1000; 转 200 事务成功; A:800 B:1200

 隔离性:事务之间互相隔离。

 持久性:一旦事务成功,数据一定会落盘在数据库。 在以往的单体应用中,我们多个业务操作使用同一条连接操作不同的数据表,一旦有异常, 我们可以很容易的整体回滚;

Business:我们具体的业务代码

Storage:库存业务代码;扣库存

Order:订单业务代码;保存订单

Account:账号业务代码;减账户余额

比如买东西业务,扣库存,下订单,账户扣款,是一个整体;必须同时成功或者失败 一个事务开始,代表以下的所有操作都在同一个连接里面;

2、事务的隔离级别

 READ UNCOMMITTED(读未提交) 该隔离级别的事务会读到其它未提交事务的数据,此现象也称之为脏读。

 READ COMMITTED(读提交) 一个事务可以读取另一个已提交的事务,多次读取会造成不一样的结果,此现象称为不可重 复读问题,Oracle 和 SQL Server 的默认隔离级别。

 REPEATABLE READ(可重复读) 该隔离级别是 MySQL 默认的隔离级别,在同一个事务里,select 的结果是事务开始时时间 点的状态,因此,同样的 select 操作读到的结果会是一致的,但是,会有幻读现象。MySQL的 InnoDB 引擎可以通过 next-key locks 机制(参考下文"行锁的算法"一节)来避免幻读。

 SERIALIZABLE(序列化) 在该隔离级别下事务都是串行顺序执行的,MySQL 数据库的InnoDB 引擎会给读操作隐式 加一把读共享锁,从而避免了脏读、不可重读复读和幻读问题。

3、事务的传播行为

1、PROPAGATION_REQUIRED:如果当前没有事务,就创建一个新事务,如果当前存在事务, 就加入该事务,该设置是最常用的设置。

2、PROPAGATION_SUPPORTS:支持当前事务,如果当前存在事务,就加入该事务,如果当 前不存在事务,就以非事务执行。

3、PROPAGATION_MANDATORY:支持当前事务,如果当前存在事务,就加入该事务,如果 当前不存在事务,就抛出异常。

4、PROPAGATION_REQUIRES_NEW:创建新事务,无论当前存不存在事务,都创建新事务。

5、PROPAGATION_NOT_SUPPORTED:以非事务方式执行操作,如果当前存在事务,就把当 前事务挂起。

6、PROPAGATION_NEVER:以非事务方式执行,如果当前存在事务,则抛出异常。

7、PROPAGATION_NESTED:如果当前存在事务,则在嵌套事务内执行。如果当前没有事务, 则执行与 PROPAGATION_REQUIRED 类似的操作。

 

@Transactional注解

@Transactional注解 可以作用于接口、接口方法、类以及类方法上。当作用于类上时,该类的所有 public 方法将都具有该类型的事务属性,同时,我们也可以在方法级别使用该标注来覆盖类级别的定义。

Spring 建议不要在接口或者接口方法上使用该注解,因为这只有在使用基于接口的代理时它才会生效。另外, @Transactional注解应该只被应用到 public 方法上,这是由Spring AOP的本质决定的。如果你在 protected、private 或者默认可见性的方法上使用@Transactional 注解,这将被忽略,也不会抛出任何异常。

@Transactional注解属性

  @Transactional注解里面的各个属性和咱们在上面讲的事务属性里面是一一对应的。用来设置事务的传播行为、隔离规则、回滚规则、事务超时、是否只读。

1. @Target({ElementType.METHOD, ElementType.TYPE})
2. @Retention(RetentionPolicy.RUNTIME)
3. @Inherited
4. @Documented
5. public @interface Transactional {
6. 
7. /**
8.      * 当在配置文件中有多个 TransactionManager , 可以用该属性指定选择哪个事务管理器。
9.      */
10. @AliasFor("transactionManager")
11.     String value() default "";
12. 
13. /**
14.      * 同上。
15.      */
16. @AliasFor("value")
17.     String transactionManager() default "";
18. 
19. /**
20.      * 事务的传播行为,默认值为 REQUIRED。
21.      */
22.     Propagation propagation() default Propagation.REQUIRED;
23. 
24. /**
25.      * 事务的隔离规则,默认值采用 DEFAULT。
26.      */
27.     Isolation isolation() default Isolation.DEFAULT;
28. 
29. /**
30.      * 事务超时时间。
31.      */
32. int timeout() default TransactionDefinition.TIMEOUT_DEFAULT;
33. 
34. /**
35.      * 是否只读事务
36.      */
37. boolean readOnly() default false;
38. 
39. /**
40.      * 用于指定能够触发事务回滚的异常类型。
41.      */
42.     Class<? extends Throwable>[] rollbackFor() default {};
43. 
44. /**
45.      * 同上,指定类名。
46.      */
47.     String[] rollbackForClassName() default {};
48. 
49. /**
50.      * 用于指定不会触发事务回滚的异常类型
51.      */
52.     Class<? extends Throwable>[] noRollbackFor() default {};
53. 
54. /**
55.      * 同上,指定类名
56.      */
57.     String[] noRollbackForClassName() default {};
58. 
59. }

4、SpringBoot 事务关键点

1、事务的自动配置

TransactionAutoConfiguration

2、事务的坑

在同一个类里面,编写两个方法,内部调用的时候,会导致事务设置失效。原因是没有用到代理对象的缘故。 解决:

0)、导入 spring-boot-starter-aop

1)、@EnableTransactionManagement(proxyTargetClass = true)

2)、@EnableAspectJAutoProxy(exposeProxy=true)

3)、AopContext.currentProxy() 调用方法


相关文章
|
9月前
|
Java Spring
SpringBoot中事务执行原理分析(三)
SpringBoot中事务执行原理分析(三)
79 0
|
3月前
|
存储 缓存 Java
SpringBoot 整合多数据源的事务问题
多数据源实现、切面的优先级问题(Order注解)、事务的传播特性(Propagation类)
|
9月前
|
Java 关系型数据库 MySQL
SpringBoot手动提交事务
SpringBoot手动提交事务
501 0
|
3月前
|
SQL Java 关系型数据库
Springboot事务处理
Springboot事务处理
|
3月前
|
Java
SpringBoot事务的使用以及开启
SpringBoot事务的使用以及开启
15 0
|
3月前
|
Java Spring
SpringBoot 开启事务Spring事务常用
SpringBoot 开启事务Spring事务常用
30 0
|
Java 数据库连接 Spring
Springboot + mybatisPlus 的多数据源的事务
springboot开箱即用就不多说,mybatisplus强大的持久层插件,一键生成代码。这二者的结合可以使得开发效率大幅度提升。然而对于初学着,多数据源及多数据源下的事务的处理,可能让你头疼。
4266 0
|
3月前
|
Java API 数据库
SpringBoot - 优雅的处理【长事务】
SpringBoot - 优雅的处理【长事务】
118 0
|
8月前
|
XML 设计模式 Java
SpringBoot中事务执行原理分析(一)
SpringBoot中事务执行原理分析(一)
77 1
|
3月前
|
SQL Java 数据库连接
SpringBoot中事务执行原理分析(六)
SpringBoot中事务执行原理分析(六)
73 0