千家信息网

怎么理解mysql特性semi consistent read

发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,这篇文章主要讲解了"怎么理解mysql特性semi consistent read",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"怎么理解mysql特性
千家信息网最后更新 2025年11月07日怎么理解mysql特性semi consistent read

这篇文章主要讲解了"怎么理解mysql特性semi consistent read",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"怎么理解mysql特性semi consistent read"吧!

先看看官方的说法:
semi consistent read

A type of read operation used for UPDATE statements, that is a combination of read committed and consistent read. When an UPDATE statement examines a row that is already locked, InnoDB returns the latest committed version to MySQL so that MySQL can determine whether the row matches the WHERE condition of the UPDATE. If the row matches (must be updated), MySQL reads the row again, and this time InnoDB either locks it or waits for a lock on it. This type of read operation can only happen when the transaction has the read committed isolation level, or when the innodb_locks_unsafe_for_binlog option is enabled.


简单来说,semi-consistent read是read committed与consistent read两者的结合。一个update语句,如果读到一行已经加锁的记录,此时InnoDB返回记录最近提交的版本,由MySQL上层判断此版本是否满足update的where条件。若满足(需要更新),则MySQL会重新发起一次读操作,此时会读取行的最新版本(并加锁)。


semi-consistent read只会发生在read committed隔离级别或以下,或者是参数innodb_locks_unsafe_for_binlog被设置为true。


semi consistent read作用情形:
1、RC、RU模式下,或者 innodb_locks_unsafe_for_binlog = 1
2、先执行非UPDATE SQL,后执行UPDATE,不会阻塞。如果先执行UPDATE,后执行其他非UPDATE SQL,则还是会加锁
3、只影响有实际存在的行,不存在的行也OK

我的理解:
在rc级别或以下级别(ru),或者 innodb_locks_unsafe_for_binlog = 1(RR) 这三种情况下,会发生semi_consistent_read.
因为innodb是行级锁,如果字段没有索引,在加锁时,会上升为表锁.此时,如果s1执行加锁任何操作,s2执行update操作,在s2的update条件中如果在s1中没有行锁,将不会堵塞s2.原理是:s2发起的update,有mysql上层根据update条件判断是否满足,若条件中没有行锁,则mysql会重新发起一次读操作,并在update后加锁;

同理:如果列是有索引存在的.innodb会自动产生的是行锁,所以semi_consistent_read的效能也就没有什么意义..
所以.semi_consistent_read只发生在没有索引的列,或者有全表锁的情况;只要存在update的数据上有行锁的,semi_consistent_read就失效;

感谢各位的阅读,以上就是"怎么理解mysql特性semi consistent read"的内容了,经过本文的学习后,相信大家对怎么理解mysql特性semi consistent read这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!

特性 条件 情况 版本 索引 级别 学习 上层 内容 一行 作用 原理 参数 字段 官方 实际 就是 思路 情形 意义 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 什么计算机的语言用于软件开发 福建销售软件开发中心 网络安全培训上的讲话 资源更新服务器未启动 浦发银行网银显示服务器连接失败 远程办公需要提高网络安全要求 服务器带宽是什么决定的 海南工业软件开发出厂价格 用友软件数据库 网络技术人才简介 数字时代网络安全挑战 软件开发售卖要办哪些资质 数据库创建规则 第17课初识数据库 为什么服务器维护时不能登录 山东省服务好的浪潮服务器销售 小班网络安全教案及反思 黄冈试卷软件开发 塔式服务器电源可以修复吗 钣金服务器外壳批发 linux服务器配置监听 如何利用服务器赚钱 电力系统开展网络安全测评 帆软报表连接实时数据库 网络安全信息文案怎么写 企业常用的网络安全协议 河北it软件开发销售电话 数据库违反唯一约束条件怎么办 泰州服务器工控机应用案例 易语言服务器优化器
0