MySQL深入——11

我们今天来谈谈幻读

在MySQL当中特别是InnoDB引擎下,如果select后加了locked in share mode,或者update就是当前读,否则就是一致性读。

我们在当前读的情况下进行下面情况的模拟,

我们插入数据(0,0,0)~(5,5,5)他们对应的是(id,c,d)

我们开三个事务ABC,他们的执行顺序是这样的:

1. A事务读 where d=5

2. B事务update t set d=5 where id=0

3.A事务读where d=5

3. C事务insert into t valuse(1,1,5)

4.A事务读where d=5

在一个事务当中因为其他事务对数据的更改导致后一次查询相同对象的时候,后一次看到了前一次没有看到的行,称之为幻读。

那么我们如果给A事务读的过程中给这一行加上锁呢?即为where d =5 for update。

这样执行下来,我们会发现出了很大的问题,A事务在执行的过程中就是声明了给所有d=5的这一行加上了锁,但是我们在B事务当中进行更改之后也出现了d=5的这一行(C事务也进行了更改,与B事务相同),出现了数据的更改,数据一致性不同,并且A事务的语义也被破坏了,这就是问题所在的地方。

我们如果给所有扫到的数据加上锁会怎么样呢?我们来分析看看,为了方便分析,我们给多加点步骤

1. A事务读 where d=5,update t set d=100 where d=5

2. B事务update t set d=5 where id=0,update t set c=5 where id =0

3.A事务读where d=5

3. C事务insert into t valuse(1,1,5),update t set c=5 where id =1

4.A事务读where d=5

5.commit;

我们来看看是如何执行的,首先时刻1的时候给所有d=5都加上了锁,接着到了b事务,因为扫到的所有行都加上了锁,所以得等锁释放了才能执行,即为在5时刻等A事务commit之后,但是C事务当中的添加并不是原有的所以并不会被加上锁,执行过程是这样的。

首先C事务将数据加入,然后对这个刚加入的数据进行修改工作,因为这行是没有加锁的,然后事务A提交,释放锁,开始执行,将所以的d=5的行改为100,然后进行B事务的操作。

我们可以看到,就算给所以的行加上锁了,也阻止不了新增加的数据,那么幻读到底该怎么处理呢?

产生幻读的原因是,行锁只能锁住行,但是新插入数据的这个操作是进行行的更新,这是不加锁的,所以为了解决这种问题,InnoDB引入了间隙锁的概念,所谓间隙锁就是在数据直接加锁,防止你插入新数据导致幻读的产生。

但是这种间隙锁的引入,也带来了一些问题,就比如说触发死锁,(问题大概是:查询数据,数据不存在时进行更新插入)当A事务对一个不存在的数据进行查询的时候会加入间隙锁,然后B查询一个不存在的数据,也会触发间隙锁,但是如果A和B这个时候要进行数据的插入,A会被B的间隙锁挡住进入等待,B也会被A的间隙锁挡住,进入等待,最终成为死锁。

我们可以发现,间隙锁的引入,可能会导致同样的语句锁住更大的范围,这其实是影响了并发度的。

这些问题的分析下都是在可重复读的隔离级别下实现的,也就是说间隙锁是在可重复读的隔离级别下才会生效的,所以我们要把隔离级别设置为读提交,为了解决数据和日志不一致的问题,我们得将binlog的格式设置为row。

将binlog的格式设置为row可以:

  1. 准确复制修改的行记录,避免了语句复制模式下的不确定性问题。
  2. 在主从复制时不易出现问题,能确保数据的一致性。
  3. 在没有主键的情况下复制更快,只有行锁,更少的锁。
  4. 适用于对数据一致性要求较高的场景,特别是涉及一些复杂的数据库操作和业务逻辑。

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

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

相关文章

go 中sync.Once的使用和优缺点

sync.Once 是 Go 语言标准库中提供的一个工具,用于确保某个操作只会执行一次。它的主要作用是在并发环境下,保证某个函数只被调用一次,而且所有并发调用该函数的 goroutine 都会等待该函数执行完成。下面是 sync.Once 的基本用法以及一些优缺…

C语言实现字符串旋转的两种方法详解

处理字符串旋转问题时可以采用不同的策略。以下代码片段展示了两种方法:一种是直接移动字符的暴力求解法,另一种则是通过反转子串实现的高效三步法。 方法一:暴力求解(left_move函数) // 定义一个函数,用…

Go模板后端渲染时vue单页面冲突处理

go后端模版语法是通过 {{}} ,vue也是通过双花括号来渲染的,如果使用go渲染vue的html页面的时候就会报错,因为分别不出来哪个是vue的,哪个是go的,既可以修改go的模板语法 template.New("output").Delims(&qu…

谷歌浏览器安装不在默认安装位置Selenium无法打开解决方法

Selenium之cannot find Chrome binary错误-CSDN博客 上面是我找的解决方案的链接 通过option.setBinary()的方法来指定谷歌浏览器的实际运行文件路径; 下面是结合我这边具体情况下写的代码 option.setBinary()中的路径是谷歌浏览器运行文件的路径;Sy…

python进行简单的app自动化测试(pywinauto)+ 截屏微信二维码

一、开始需要了解准备 1、安装 pip install pywinauto2、选择(后面会通过工具进行判断用哪个) 3、自动化控制进程的范围 示例 Application单进程 Desktop多进程 4、程序辅助检测工具 3中的下载连接 链接 点击放大镜拖到对应位置即可 二、简单的开始…

【C语言】ipoib驱动 - ipoib_cm_post_receive_srq_rss函数

一、ipoib_cm_post_receive_srq_rss函数定义 static int ipoib_cm_post_receive_srq_rss(struct net_device *dev,int index, int id) {struct ipoib_dev_priv *priv ipoib_priv(dev);struct ipoib_recv_ring *recv_ring priv->recv_ring index;struct ib_sge *sge;stru…

Redis(四)事务

文章目录 事务Redis事务 vs 数据库事务常用命令总结 事务 一个队列中、一次性、顺序性、排他性执行一系列命令 官网https://redis.io/docs/interact/transactions/ Redis事务 vs 数据库事务 概述详述1、单独的隔离操作Redis的事务仅仅是保证事务里的操作会被连续独占的执行&a…

探索计算机网络:应用层的魅力

在当今数字化时代,计算机网络已成为我们生活和工作中不可或缺的一部分。网络的每一层都扮演着独特而重要的角色,而应用层,作为网络模型中用户最直接接触的部分,其重要性不言而喻。这篇文章旨在深入探索应用层的核心概念、功能以及…

原生微信小程序-两次设置支付密码校验,密码设置二次确认

效果 具体代码 1、wxml <view style"{{themeColor}}"><view classcontainer><view class"password_content"><view wx:if{{type 1}}><view class"title"><view class"main_title">设置支付密码…

WXUI 基于uni-app x开发的高性能混合UI库

uni-app x 是什么&#xff1f; uni-app x&#xff0c;是下一代 uni-app&#xff0c;是一个跨平台应用开发引擎。 uni-app x 没有使用js和webview&#xff0c;它基于 uts 语言。在App端&#xff0c;uts在iOS编译为swift、在Android编译为kotlin&#xff0c;完全达到了原生应用…

紫光展锐5G扬帆出海 | Blade系列勇当拉美5G先锋

5G对拉丁美洲&#xff08;简称“拉美”&#xff09;绝大多数消费者来说还是一个新鲜技术。GSMA报告显示&#xff0c;过去五年&#xff0c;拉美运营商在移动网络方面的资本开支大部分用于部署4G网络。但在5G网络方面拉美也在积极大力投入中&#xff0c;紧跟全球5G发展大潮&#…

Google I/O大会:Android 13

3个体验升级的方向 以智能手机为场景核心、 扩大智能终端的应用边界以及实现多设备间更好地协同。具体到系统体验层&#xff0c;安卓13将支持图标颜色随主题更换、为不同应用设定使用的语言、新的媒体中心界面等等&#xff0c;同时谷歌也推出了自家的钱包应用&#xff08;Goog…

Golang+Qt合作 : go-echarts + QWebEngineView

简介 无聊使用了一下go-echarts, 使用Qt在C/S模式下嵌入使用B/S框架的简单例子 材料 Qt 5.15.0 MSVC-2019-64bit Golang1.14.3 go-echarts 代码 Golang (Server端) 浏览器 localhost:8081 可以进行访问, 示例来自于 https://go-echarts.github.io/go-echarts/docs/kline …

DevOps系列之 Python操作数据库

pymysql操作mysql数据库 安装pymysql pip install pymysql pymysql操作数据库 1.连接数据库 使用Connect方法连接数据库 pymysql.Connections.Connection(hostNone, userNone, password, databaseNone, port0, charset) 参数说明&#xff1a; host – 数据库服务器所在的主机…

2024.1.9力扣每日一题——字符串中的额外

2024.1.9 题目来源我的题解方法一 集合动态规划方法二 字典树动态规划 题目来源 力扣每日一题&#xff1b;题序&#xff1a;2707 我的题解 方法一 集合动态规划 题目的要求是讲字符串s划分为多个不重叠的子串&#xff0c;然后尽可能使得更多的子串匹配到dictionary中的字符串…

【笔记】Helm-3 主题-2 Chart Hook

Chart Hook Helm提供了一个hook机制允许开发者在发布声明周期的某些点进行干预。比如您可以使用hook用于&#xff1a; 1、安装时在加载其他chart之前加载配置映射或密钥 2、安装新chart之前执行备份数据库的任务&#xff0c;然后在升级之后执行第二个任务用于存储数据。 3、…

mysql的gtid主从复制,从库误操作更新操作,

一&#xff1a;查看mysql的从库&#xff0c;发现sql进程状态 “no”.提示执行传输过来的binlog日志&#xff0c;执行失败&#xff0c; 二&#xff1a;查看主库对应的二进制日志的gtid地方。插入一些数据。 # mysqlbinlog --base64-outputdecode-rows -v mysql-bin.000001 |gre…

2019年认证杯SPSSPRO杯数学建模C题(第一阶段)保险业的数字化变革全过程文档及程序

2019年认证杯SPSSPRO杯数学建模 基于 CART 决策树和 SVR 的客户续保概率预测 C题 保险业的数字化变革 原题再现&#xff1a; 车险&#xff0c;即机动车辆保险。保险自身是一种分散风险、消化损失的经济补偿制度&#xff0c;车险即为分散机动车辆在行驶过程中可能发作的未知风…

21道Java Spring MVC综合面试题详解含答案(值得珍藏)

1.概述 1.1 什么是Spring MVC&#xff1f;简单介绍下你对Spring MVC的理解&#xff1f; Spring MVC是一个基于Java的实现了MVC设计模式的请求驱动类型的轻量级Web框架&#xff0c;通过把模型-视图-控制器分离&#xff0c;将web层进行职责解耦&#xff0c;把复杂的web应用分成…

CMake入门教程【高级篇】文件操作(file)

😈「CSDN主页」:传送门 😈「Bilibil首页」:传送门 😈「动动你的小手」:点赞👍收藏⭐️评论📝 文章目录 1.概述2.使用说明3.完整代码示例4.实际使用中的技巧1.概述 在 CMake 项目中,file 命令是一个多功能工具,用于执行各种文件操作,如读写文件、复制和重命名文…