怀旧网,博客详情:数据库 事务 讲解

1、数据库 事务 讲解

原创

数据库 事务 讲解

ACID 介绍

事务的ACID特性:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability)。

原子性

要么都执行,要么都不执行。

通常,与某个事务关联的操作具有共同的目标,并且是相互依赖的。如果系统只执行这些操作的一个子集,则可能会破坏事务的总体目标。原子性消除了系统处理操作子集的可能性。

一致性

数据库的状态在执行该事务操作之后从一个状态改变到了另一个状态。

事务在完成时,必须使所有的数据都保持一致状态(各种 constraint 不被破坏)。

隔离性

由并发事务所作的修改必须与其他并发事务所作的修改隔离。

事务查看数据时数据所处的状态,要么是另一并发事务修改它之前的状态,要么是另一事务修改它之后的状态,事务不会查看中间状态的数据。 换句话说,一个事务的影响在该事务提交前对其他事务都不可见。

隔离性可能发生的问题

image-20240321165314441

持久性

事务完成之后,它对于系统的影响是永久性的。该修改即使出现致命的系统故障也将一直保持。

数据库 ACID 中的一致性对事务的要求不止包含对数据完整性以及合法性的检查,还包含应用层面逻辑的正确。 CAP 定理中的数据一致性,其实是说分布式系统中的各个节点中对于同一数据的拷贝有着相同的值;而 ACID 中的一致性是指数据库的规则,如果 schema 中规定了一个值必须是唯一的,那么一致的系统必须确保在所有的操作中,该值都是唯一的,由此来看 CAP 和 ACID 对于一致性的定义有着根本性的区别。

事务的执行流程

image-20240321170135661

image-20240321170231886

模拟事务过程

1、创建数据表

image-20240321170949353

2、插入数据

image-20240321171002749

image-20240321171007433

3、 模拟转账

A给B转账500元

image-20240321171349418

image-20240321171503525

image-20240321171455828

image-20240321171516904

image-20240321171522324

image-20240321171536039

image-20240321171543467

4、点击回滚后,数据直接恢复

image-20240321171553092

image-20240321171557314

image-20240321171605986

image-20240321171617121

image-20240321171624718

image-20240321171631398

5、当事务提交后,在点击回滚,回滚失败。

image-20240321172129676

事务的隔离级别

四个隔离级别以及对应的问题

事务隔离级别脏读不可重复读幻读
读未提交允许允许允许
读已提交禁止允许允许
可重复度禁止禁止可能会
顺序读禁止禁止禁止

SQL 标准定义了四个隔离级别:

1、READ-UNCOMMITTED(读取未提交): 最低的隔离级别,允许读取尚未提交的数据变更,可能会导致脏读、幻读或不可重复读。 2、READ-COMMITTED(读取已提交): 允许读取并发事务已经提交的数据,可以阻止脏读,但是幻读或不可重复读仍有可能发生。 3、REPEATABLE-READ(可重复读): 对同一字段的多次读取结果都是一致的,除非数据是被本身事务自己所修改,可以阻止脏读和不可重复读,但幻读仍有可能发生。 4、SERIALIZABLE(可串行化): 最高的隔离级别,完全服从ACID的隔离级别。所有的事务依次逐个执行,这样事务之间就完全不可能产生干扰,也就是说,该级别可以防止脏读、不可重复读以及幻读。

注意:

1、 这里需要注意的是:Mysql 默认采用的 REPEATABLE_READ隔离级别 Oracle 默认采用的 READ_COMMITTED隔离级别

2、事务隔离机制的实现基于锁机制和并发调度。其中并发调度使用的是MVVC(多版本并发控制),通过保存修改的旧版本信息来支持并发一致性读和回滚等特性。

3、因为隔离级别越低,事务请求的锁越少,所以大部分数据库系统的隔离级别都是READ-COMMITTED(读取提交内容):,但是你要知道的是InnoDB 存储引擎默认使用 **REPEATABLE-READ(可重读)**并不会有任何性能损失。

  • 平台作者:怀旧(联系作者)
  • QQ:444915368
  • 邮箱:444915368@qq.com
  • 电话:17623747368
  • 评论

    登录后才可以进行评论哦!

    回到顶部 留言