热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

mysql幻读是什么?会产生什么问题?怎么解决幻读?

幻读是什么?幻读是事务A在执行查询一条记录是否存在而进行插入时,在查询完毕,插入记录前的

幻读是什么?

幻读是事务A在执行查询一条记录是否存在而进行插入时,在查询完毕,插入记录前的间隙中,事务B插入了这条数据,事务A在插入这条数据时会失败。
幻读会产生什么问题呢?

幻读可能产生数据一致性问题,数据一致性不仅指的是数据库内部数据状态,也包含日志逻辑和数据的一致性。下图就说明下这个问题:

可以看到上图中A会话的语义是把d=5修改为100其最终提交是在t6时刻,B会话的语义是在t2时刻把id=0的c、d修改为5,C会话的语义是在t4时刻加入一条数据(1,1,5),修改id=1的c为5。但是其在binlog中写的顺序是B和C先执行,A最后执行,就会导致所有d=5的值修改为100,这不符合我们想要的数据。如果我们把所有扫描到的数据都加上了锁,C会话中的插入的数据原先不存在,所以不会阻塞住。

怎么解决幻读?

在InnoDB中引入了间隙锁(Gap Lock),即锁住两个记录之间的间隙。间隙锁+行锁被称为范围锁(next-key Lock)。间隙锁可以解决幻读的问题,那会带来其他的问题么?答案是会的,间隙锁会带来死锁的,比如下图中的操作:

A会话中的查询会给(5,10)加间隙锁,由于查询语句不会冲突,所以B会话也会在(5,10)加上间隙锁。这时B会话执行插入操作会阻塞,需要等待A会话中锁释放。而A会话执行插入操作也会阻塞,需要等待B会话中锁释放,这样死锁就形成了。

间隙锁和范围锁的加锁规则

加锁规则:

  1. 加锁时,锁的类型是范围锁。只会把扫描到的数据加锁

  2. 索引上的等值查询,是唯一索引的话,范围锁退化成行锁

  3. 索引上的等值查询,向右遍历时,且最后一个值不满足等值条件时,范围锁退化成间隙锁

下面来贴出几个操作实例,可以自己测下:

在上图的A会话中会锁住(5,10],(10,15)区间,但是由于>=10是等值查询,并且在唯一索引上,结合上面的加锁规则,会退化成行锁,只锁住连id=10这行记录。

在上图的A会话会锁住(10,15],(15,20)区间,结合加锁规则3,导致后面的B会话和C会话的操作阻塞。

这篇文章对幻读是什么?会产生何种问题然后怎么解决进行了学习,希望可以给读者分享更多的所学。



推荐阅读
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • 网络攻防实战:从HTTP到HTTPS的演变
    本文通过一系列日记记录了从发现漏洞到逐步加强安全措施的过程,探讨了如何应对网络攻击并最终实现全面的安全防护。 ... [详细]
  • andr ... [详细]
  • PHP 编程疑难解析与知识点汇总
    本文详细解答了 PHP 编程中的常见问题,并提供了丰富的代码示例和解决方案,帮助开发者更好地理解和应用 PHP 知识。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 本文详细介绍了如何使用 Yii2 的 GridView 组件在列表页面实现数据的直接编辑功能。通过具体的代码示例和步骤,帮助开发者快速掌握这一实用技巧。 ... [详细]
  • 本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ... [详细]
  • MongoDB集群配置:副本集与分片详解
    本文详细介绍了如何在MongoDB中配置副本集(Replica Sets)和分片(Sharding),并提供了具体的步骤和命令,帮助读者理解并实现高可用性和水平扩展的MongoDB集群。 ... [详细]
  • 本文详细介绍了 MySQL 的查询处理流程,包括从客户端连接到服务器、查询缓存检查、语句解析、查询优化及执行等步骤。同时,深入探讨了 MySQL 中的乐观锁机制及其在并发控制中的应用。 ... [详细]
  • 网络运维工程师负责确保企业IT基础设施的稳定运行,保障业务连续性和数据安全。他们需要具备多种技能,包括搭建和维护网络环境、监控系统性能、处理突发事件等。本文将探讨网络运维工程师的职业前景及其平均薪酬水平。 ... [详细]
  • 高效解决应用崩溃问题!友盟新版错误分析工具全面升级
    友盟推出的最新版错误分析工具,专为移动开发者设计,提供强大的Crash收集与分析功能。该工具能够实时监控App运行状态,快速发现并修复错误,显著提升应用的稳定性和用户体验。 ... [详细]
author-avatar
海滨的微博小窝
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有