for update语句锁机制问题
2024-10-09 03:33:55
数据库小知识学习系列
问题:
MySQL InnoDB中,select where xxx=123 for update;该xxx没有索引,是使用表锁还是全部数据加行锁?
答:
InnoDB引擎(默认RR隔离级别)中的行级锁是依赖索引实现的,问题条件xxx为非索引字段,所以使用的是表锁。
如若隔离级别为RC,则通过 where 条件走非索引列过滤之后(where xxx=123),不符合条件的记录上的行锁,会释放掉。也就是先表锁后释放非过滤条件的行锁。
ps:如果是Oracle,由于默认使用RC隔离,效果与上面MySQL的RC隔离效果一致
补充知识:RC 与 RR 在锁方面的区别
RR 支持 gap lock(next-key lock),而RC则没有gap lock。因为MySQL的RR需要gap lock来解决幻读问题。而RC隔离级别则是允许存在不可重复读和幻读的。所以RC的并发一般要好于RR;
RC 隔离级别,通过 where 条件过滤之后,不符合条件的记录上的行锁,会释放掉(虽然这里破坏了“两阶段加锁原则”);但是RR隔离级别,通过 where 条件走非索引列过滤之后,即使不符合where条件的记录,也是会加行锁。所以从锁方面来看,RC的并发应该要好于RR;可以减少一部分锁竞争,减少死锁和锁超时的概率。
纯学习交流,有任何不对还请随时评论指出交流。
最新文章
- c#制作一个屏幕保护程序
- typename
- 创建一个ArcGIS for Android 新项目并显示出本地的地图
- 基于Winform、WPF等的客户端文件下载
- JavaScript中sort方法的一个坑(leetcode 179. Largest Number)
- (六)6.15 Neurons Networks Deep Belief Networks
- show/hide
- 高效的TCP消息发送组件
- CSS美化 input type=file 兼容各个浏览器(转)
- NSTimer 详细设置
- 使用URLConnection提交请求
- TCP/UDP简介
- 学习ASP.NET Core Razor 编程系列五——Asp.Net Core Razor新建模板页面
- centos6.5安装Mysql5.6及更改密码
- 京东饭粒捡漏V1.15
- 20165231 实验一 Java开发环境的熟悉
- #include<;bits/stdc++.h>;的使用
- C# dynamic类型报错:“object”不包含“xxx”的定义
- 【Centos】centos查看磁盘使用情况
- conductor 事件处理程序
热门文章
- scala&;&;spark学习参考文章
- 函数动态参数 *args **kwargs
- STL—— 容器(vector)的数据写入、修改和删除
- 项目中对获取的数据进行下载成Excel表格
- sqli-labs less38-53(堆叠注入 order by之后相关注入)
- 在Linux下下载RPM包
- Web服务器-并发服务器-多进程(3.4.1)
- C#中的深度学习(二):预处理识别硬币的数据集
- python菜鸟教程学习:数据结构
- Python利用openpyxl带格式统计数据(2)- 处理mysql数据