IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> MySQL事务学习 -> 正文阅读

[大数据]MySQL事务学习

事务重点知识

什么是事务?

数据库操作的最小工作单元,是作为单个逻辑工作单元执行的一系列操作;这些操作作为一个整体一起向系统提交,要么都执行、要么都不执行;事务是一组不可再分割的操作集合。事务在执行的过程中,不会被其他客户端发送的命令请求所打断。

事务四大特性(ACID)

原子性:事务是最小的执行单位,要么全成功,要么全失败。

一致性:事务应确保数据库的状态从一个一致状态转变为另一个一致状态。一致状态的含义是数据库中的数据应满足完整性约束。
如果数据库系统运行中发生故障,有些事务尚未完成就被迫中断,这些未完成事务对数据库所做的修改有一部分已写入物理数据库的话,这时数据库就处于一种不正确的状态,或者说不一致的状态。

隔离性:一个事务内部的操作及使用的数据对其他并发事务是隔离性的,多个事务并发执行时,一个事务的执行不影响其他事务的执行。
四种隔离级别:RU(读未提交)、RC(读已提交)、RR(可重复读)、SERIALIZABLE (串行化)

持续性:事务提交后,对数据的修改是永久性的,即使系统故障也不会丢失。

事务的并发问题,什么是脏读?幻读?不可重复读?

脏读: 当前事务可以读到其他事务未提交的数据(脏数据)

不可重复读: 事务两次读同一个数据,数据不同。

  • 脏读与不可重复读的区别:前者读到的是其他事务未提交的数据,后者读到的是其他事务已提交的数据。

幻读: 事务两次读同一条数据,条数不同。 例如有一个事务查询了几列(row)数据,而另一个事务却在此时插入了新的几列数据,之前的事务在接下来的查询中,就会发现有几列数据是它先前没有的。

  • 不可重复的与幻读的区别:前者是数据变了,后者是数据的行数变了。
  • 不可重复读的和幻读很容易混淆,不可重复读侧重于修改,幻读侧重于新增或删除。解决不可重复读的问题只需锁住满足条件的行,解决幻读需要锁表

事务的隔离级别

读未提交: 最低的隔离级别,允许读取尚未提交的数据变更,可能会导致脏读、幻读、不可重复读。

读已提交: 允许读取并发事务已经提交的数据,可以阻止脏读,但可能发生幻读或不可重复读。

可重复读: mysql默认隔离级别 。对同一字段的多次读取结果都是一致的,除非数据是被本身事务自己所修改,可以阻止脏读和不可重复读,但仍可能发生幻读。

可串行化: 最高隔离级别,完全服从ACID。所有的事务依次逐个执行,事务之间不可能产生干扰,可以防止脏读、不可重复读、幻读。

  • MySQL默认采用可重复读隔离级别,Oracle默认采用读已提交。
  • 事务隔离机制的实现基于锁机制和并发调度。其中并发调度使用的是MVVC(多版本并发控制),通过保存修改的旧版本信息来支持并发一致性读和回滚等特性。
  • 隔离级别越低,事务请求的锁越少,所以大部分数据库系统的隔离级别都是读已提交,但是InnoDB使用的是可重复读。
  • InnoDB引擎在分布式事务的情况下一般会用到可串行化隔离级别。什么是分布式事务?

在这里插入图片描述

如何实现ACID

深入学习MySQL事务:ACID特性的实现原理
原子性: 实现原子性的关键是当事务回滚时能够撤销所有已经成功执行的sql语句。InnoDB实现回滚靠的是undo log :当事务对数据库进行修改时,InnoDB会生成对应的undo log ;如果事务执行失败或调用了 rollback, 导致事务需要回滚,便可以利用undo log 中的信息将数据回滚到修改之前的样子。

一致性:

  1. 保证原子性、持久性和隔离性,如果这些特性无法保证,事务的一致性也无法保证
  2. 数据库本身提供保障,例如不允许向整形列插入字符串值、字符串长度不能超过列的限制等
  3. 应用层面进行保障,例如如果转账操作只扣除转账者的余额,而没有增加接收者的余额,无论数据库实现的多么完美,也无法保证状态的一致

隔离性: 各个隔离级别原理各不相同

持久性: MySQL事务的持久性是通过redo log来实现的。redo log也是InnoDB存储引擎特有的。具体实现方式是:当数据修改时,除了修改Buffer Pool中的数据,还会在redo log记录这次操作;当事务提交时,会调用fsync接口对redo log进行刷盘。如果MySQL宕机,重启时可以读取redo log中的数据,对数据库进行恢复。redo log采用的是WAL(Write-ahead logging,预写式日志),所有修改先写入日志,再更新到Buffer Pool,保证了数据不会因MySQL宕机而丢失,从而满足了持久性要求。
redo log是物理日志,记录的是在某个数据页做了什么修改,而不是SQL语句的形式。它有固定大小,是循环写的方式记录日志,空间用完后会覆盖之前的日志。

隔离级别实现原理

读未提交(READ UNCOMMITTED): 读不会加任何锁,写会加排它锁,并到事务结束之后释放。实例:写-写:阻塞

读已提交(READ COMMITTED): InnoDB在该隔离级别下写数据时,使用排它锁,读取数据不加锁而是使用了MVCC机制。在读已提交的级别下,都会通过MVCC获取当前数据的最新快照,不加任何锁,也无视任何锁(因为历史数据是构造出来的,身上不可能有锁)。
但是该级别下存在不可重复读和幻读问题:MVCC版本的生成时机是每次select时。这意味着如果我们在事务A中执行多次的select,在每次select之间有其他事务更新了我们读取的数据并提交了,那就出现了不可重复读。

可重复读(REPEATABLE READ): 可重复读级别不同的是MVCC版本的生成时机。 即:一次事务中只在第一次select时生成版本,后续的查询都在这个版本上进行,从而实现可重复读。
不能彻底解决。MVCC对于幻读的解决并不彻底,只解决了读情况下的幻读问题,而写操作依旧存在幻读问题

原因:

  • select读操作是快照读的模式,会记录下这次select的结果,之后select 返回的也是这次快照的数据。此时其他事务提交的数据无影响。
  • update、insert、delete写操作是当前读的模式,会记录最新的结果。此时其他事务提交的数据有影响

解决方法:

  • MVCC+next-key locks
  • 使用可串行化读的隔离级别

可串行化(SERIALISABLE): 完全使用读锁和写锁保证数据一致性。针对同一数据的所有读写都变成互斥,可靠性大大提高,并发性大大降低。

参考

  • https://blog.csdn.net/qq_42914528/article/details/103790555
  • https://www.jianshu.com/p/dab1c0ecbac0
  • https://www.cnblogs.com/kismetv/p/10331633.html
  • https://www.cnblogs.com/huanongying/p/7021555.html
  • https://blog.csdn.net/qq_43255017/article/details/106442887
  • https://blog.csdn.net/suchahaerkang/article/details/81407308
  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-11-22 12:24:30  更:2021-11-22 12:26:50 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/17 21:53:07-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码