MySQL Innodb中 可重复读隔离级别是否能完全规避幻读

一、MySQL 可重复读隔离级别下的幻读

MySQL Innodb引擎可重复读隔离级别下,已经尽可能最大程度的规避幻读的问题了,使得大多数情况下,重复读都是可以得到一致的结果。

针对于读数据,可以大致分为两种模式,快照读(select ... )保证每次数据读取相同,即使其他事务写入或更新了数据。另一种是当前读(select ... for update) 的方式,每次读取最新的数据。不过两种方式解决幻读的策略不同。

  • 快照读模式下,通过 MySQL MVCC 多版本机制解决,在执行第一个 select 语句后,会创建一个 Read View,后续的查询语句会先查询这个 Read View,通过 Read View 就可以在 undo log 版本链中找到事务开始的数据,所以整个过程中可以保证查询的数据都是一致的,即使中间被其他事务插入了新数据。

  • 当前读模式下,通过 MySQL Innodb 中的间隙锁和临键锁解决幻读,当执行 select ... for update 时,会针对相关的记录或间隙进行加锁,如果有其他事务在修改相关数据,或在间隙中新增数据,都会被阻塞,直到当前事务处理完成后才能继续操作,进而规避了幻读的发生。

不过上面两种方式虽然解决了大多数情况下的幻读问题,但是某些个别情况下还是不可避免会发生幻读。

例如有如下表结构:

CREATE TABLE `user` (`id` int NOT NULL AUTO_INCREMENT,`name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL COMMENT '姓名',`age` int DEFAULT NULL COMMENT '年龄',`grade` int DEFAULT NULL COMMENT '等级',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;

写入两条测试数据:

INSERT INTO `testdb`.`user` (`id`, `name`, `age`, `grade`) VALUES (1, '张三', 18, 1);
INSERT INTO `testdb`.`user` (`id`, `name`, `age`, `grade`) VALUES (2, '李四', 18, 1);

二、可重复读隔离级别下幻读问题复现

首先在事务1中,查询 user 表下的所有数据:

BEGIN;
select * from `user`;

在这里插入图片描述
可以正常查到两条测试数据。

下面在事务2中插入一条新数据:

BEGIN;
INSERT INTO `user`(name,age,grade) value('王五', 18, 1);
COMMIT;

在这里插入图片描述

然后回到事务 1 ,当前如果继续执行查询,应该会命中先前查询的Read View

select * from `user`;

在这里插入图片描述
看到确实没有查出事务2新增的数据,但是下面在事务1中做一个更新操作,把所有 age > 15 的用户的 grade 修改成 2 ,然后再次执行上面相同的查询语句:

update `user` set grade = 2 where age > 15;
select * from `user`;

在这里插入图片描述
可以看到此时竟然查出了事务2新增的数据,对于事务1来说出现了幻读!

此时发生幻读主要在 update 执行后,首先之前的 select 属于快照读,不会对相关数据加锁,而 update 其实属于当前读,且 update 的范围,已经包含了事务2写入并提交的数据,所以导致后面的查询看到了新插入的数据。

同样的原理,将 update 语句换成 select .... for update 同样也会出现幻读。

三、如何解决幻读

从上面的例子可以看出,可重复读隔离级别并没有彻底解决幻读问题,只是尽可能最大程度的规避幻读的问题。其实有的时候我们可以从上层去协调这种问题,比如在代码层协调执行的过程。如果非要到SQL中解决,可以在最开始的 select 就加上 for update 或者 select ... in share mode,这样相关数据都被锁上了,其他事务的写操作就会被阻塞,缺点是处理的效率就会大大折扣,具体解决方法还是要结合业务决策。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/814916.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网络篇12 | 链路层 ARP

网络篇12 | 链路层 ARP 01 简介1)工作过程2)ARP缓存2.1 动态ARP表项2.2 静态ARP表项2.3 短静态ARP表项2.4 长静态ARP表项 02 ARP报文格式1)ARP请求报文格式2)ARP响应报文格式3)套一层以太网帧(ARP帧&#x…

熟悉数电知识

23.数电 1. 建立时间、保持时间 建立时间setup time:时钟上升沿到来之前,输入端数据已经来到并稳定持续的时间。 保持时间hold time:时钟上升沿到来之后,传输端数据保持稳定并持续的时间。 2.二分频电路 每当输入一个时钟信号…

关于时频分析的一些事-答知乎问(一)

从信号的时频谱图中可以提取什么特征? 基于时频谱图的特征一般包括能量特征、时域和频域拓展特征以及时频内禀特征。 基于时频图的能量特征 基于时频图的特征中,能量特征是最简单的一种,通过分析时频谱图中的能量分布特性而获取信号的时频…

c-结构体内存对齐,位段

首先就是解释为什么要这么处理:处理器在处理已经对齐的变量时只需要一次就能够读取,而没对齐时可能就需要将该变量读取两次,(既4个字节,读了前三个字节,还剩一个字节就需要再读取一次) 接着说一…

Gitlab全量迁移

Gitlab全量迁移 一、背景1.前提条件 一、背景 公司研发使用的Gitlab由于服务器下架需要迁移到新的Gitlab服务器上。Gitlab官方推荐了先备份然后再恢复的方法。个人采用官方的另外一种方法,就写这篇文章给需要的小伙伴参考。 源Gitlab: http://old.mygitlab.com #地…

算法库应用- 表的自然链接

功 能: 设计算法,将两个单链表数组的特定位序, 相同者,链接起来 编程人: 王涛 详细博客:https://blog.csdn.net/qq_57484399/article/details/127161982 时 间: 2024.4.14 版 本: V1.0 V1.0 main.cpp /***************************************** 功 能: 设计算法,将两个…

Linux:环境基础开发工具使用

文章目录 前言1.Linux下的软件安装1.1 什么是软件包1.2 如何安装软件1.3 如何卸载软件 2.vim2.1 vim的基本概念2.2 vim的基本操作2.3 vim正常模式命令集2.4 vim末行模式命令集2.5 vim的操作总结 3.Linux下的编译器:gcc3.1 gcc的使用3.2 gcc是如何工作的3.2.1 预处理…

嵌入式学习54-ARM3(中断和时钟)

S3c2440中断控制器 内部外设: DMA :(直接内存存取) Direct Memor…

git 批量更改提交者邮箱规避 GH007 private email address 问题

问题描述 有时我们在推送提交时,会看到如下报错 remote: error: GH007: Your push would publish a private email address. remote: You can make your email public or disable this protection by visiting: remote: http://github.com/settings/emails这是因为…

基于Linux定时任务实现的MySQL周期性备份

1、创建备份目录 sudo mkdir -p /var/backups/mysql/database_name2、创建备份脚本 sudo touch /var/backups/mysql/mysqldump.sh# 用VIM编辑脚本文件,写入备份命令 sudo vim /var/backups/mysql/mysqldump.sh# 内如如下 #!/bin/bash mysqldump -uroot --single-…

Ant Design 官方推荐的实用前端工具

Ant Design 作为一款备受欢迎的 UI 组件库,不仅功能强大,还非常注重用户体验。在官网上还特别推荐了一系列其他实用的工具库,这些工具库能够与 Ant Design 形成互补,提供更为全面和高效的解决方案。通过结合这些工具,可…

数据库的负载均衡,高可用实验

一 高可用负载均衡集群数据库实验 1.实验拓扑图 2.实验准备(同一LAN区段)(ntp DNS) 客户端:IP:192.168.1.5 下载:MariaDB 负载均衡器:IP:192.168.1.1 下载:keepalived ipvsadm I…

操作系统银行家算法计算题

设系统某个T0时刻的状态,如表1所示: 表1 系统资源状态表使用银行家算法回答下面问题: (1)系统在T0时刻状态是否安全?若安全,请给出一个安全序列。 (2)假如T0时刻进程P1…

C语言指针进阶:数组与指针的联系

目录 1. 数组名的本质2. 使用指针访问数组3. 一维数组传参的本质4. 二级指针5. 指针数组5.1 指针数组模拟二维数组 正文开始。 1. 数组名的本质 数组名代表着这个数组中第一个元素的地址 例如: int arr[4] { 1,2,3,4 }; int *p1 &arr[0]; int *p2 arr;上述…

前端学习<四>JavaScript基础——22-立即执行函数

立即执行函数 IIFE 概念 函数定义完,就立即被调用,这种函数叫做立即执行函数。英文是 IIFE(Immediately-invoked function expression),立即调用函数表达式。 语法格式 语法1: (function() {// 函数体}…

【智能优化算法】河马优化算法(Hippopotamus optimization algorithm,HO)

河马优化算法(Hippopotamus optimization algorithm,HO)是发表在中科院二区期刊“Scientific Reports”的文章“Hippopotamus Optimization Algorithm: a Novel Nature-Inspired Optimization Algorithm”上的算法。 01.引言 河马优化算法&a…

RK3568平台开发系列讲解(Linux系统篇)设备树中断的属性

🚀返回专栏总目录 文章目录 一、RK ft5x06 设备树节点案例二、interrupts属性三、interrupt-controller属性四、interrupt-parent属性五、#interrupt-cells 属性沉淀、分享、成长,让自己和他人都能有所收获!😄 📢设备树中断的属性介绍。 一、RK ft5x06 设备树节点案例…

响应式导航栏不会做?看我一分钟学会制作导航栏!

引言 随着互联网技术的飞速发展,用户体验在网页设计中的重要性日益凸显。其中,导航栏作为网页的“指南针”,不仅能帮助用户快速定位所需内容,还能体现网站的整体风格和设计理念。本文将介绍如何使用HTML、CSS和JavaScript制作一个…

SpringBoot 微服务token 传递实现

1、前言 随着微服务的流行,微服务之间的安全以及业务需要,都需要穿递token ,而token的传递一般通过header 头来传递。从架构的角度来讲 ,一般的企业应用都由nginx、业务网关和各个微服务组成。这个nginx 传递header 我就不讲述。下…

[附带黑子定制款鸽鸽版素材包]更改文件夹图标,更改系统音效,更改鼠标指针及样式。

更改文件夹图标 1.选择图片在线格式转换网站转换为ico格式 2.右键文件夹选择属性 3.点击自定义,点击更改图标超链接 4.点击预览选择生成的ico文件 5.点击打开,点击确定,点击应用 更改系统音效(真爱粉强烈推荐) 1…