美文网首页
本地事务

本地事务

作者: 紫荆秋雪_文 | 来源:发表于2020-07-01 09:03 被阅读0次

一、事务的基本性质

1、数据库事务的几个特性:ACID

  • 原子性(Atomicity):一系列的操作整体不可拆分,要么同时成功,要么同时失败
  • 一致性(Consistency):数据在事务的前后,业务整体一致
  • 隔离性或独立性(Isolation):事务之间相互隔离
  • 持久性(Durabilily):一旦事务成功,数据一定会落盘在数据库

二、事务的隔离级别

1、READ UNCOMMITTED(读未提交)

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

2、READ COMMITTED(读提交)

一个事务可以读取另一个已提交的事务,多次读取会造成不一样的结果,此现象称为不可重复读问题。

3、REPEATABLE READ(可重复读)

该隔离级别是 MySQL 默认的隔离级别,在同一个事务里,select 的结果是事务开始时时间点的状态,因此,同样的 select 操作读到的结果会是一致的,但是,会有幻读现象。MySQL的 InnoDB 引擎可以通过 next-key locks 机制来避免幻读。

4、SERIALIZABLE(序列化)

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

三、事务的传播行为

  • 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 类似的操作

相关文章

  • 本地事务

    一、事务的基本性质 1、数据库事务的几个特性:ACID 原子性(Atomicity):一系列的操作整体不可拆分,要...

  • 分布式事务

    大纲 1.本地事物 - ACID - 本地事务模型2.分布式事物 - 分布式事务概念 - 跨库事务 - 服务化事务...

  • 分布式事务

    一、本地事务 1.1 概念 本地事务必须具备ACID原则 原子性(Atomicity):事务中的操作要么全部完成,...

  • 分布式事务解决方案

    本地事务 什么是本地事务?本地事务是解决单个数据源上的数据操作的一致性问题。 spring的@Transactio...

  • 分布式事务 | 使用 dotnetcore/CAP 的本地消息表

    本地消息表模式 本地消息表模式,其作为柔性事务的一种,核心是将一个分布式事务拆分为多个本地事务,事务之间通过事件消...

  • spring事务(一) 编程式事务

    spring事务(一) 编程式事务 知识导读 本地事务(autocommit=false)-----编程式事务--...

  • 【Java面试题】阿里java面试题

    编号题目备注1分布式事务、本地事务区别本地事务:对单个服务、单个数据库访问的事务;分布式事务:指事务的参与者、支持...

  • 分布式事务

    本地事务 分布式事务 分布式事务模型 XA 优点:对应用侵入很小,用户可以像使用本地事务一样使用基于XA协议的分布...

  • MQ和Mysql二阶段提交

    MQ事务消息两阶段提交过程 主要的过程为: 1、先向服务端发送半事务消息,发送成功后执行本地事务 2、本地事务执行...

  • springboot spring cloud 分布式事务 LC

    简介 LCN分布式事务框架的核心功能是对本地事务的协调控制,框架本身并不创建事务,只是对本地事务做协调控制。因此该...

网友评论

      本文标题:本地事务

      本文链接:https://www.haomeiwen.com/subject/pvgqqktx.html