数据库小知识学习系列

问题:

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;可以减少一部分锁竞争,减少死锁和锁超时的概率。


纯学习交流,有任何不对还请随时评论指出交流。

最新文章

  1. c#制作一个屏幕保护程序
  2. typename
  3. 创建一个ArcGIS for Android 新项目并显示出本地的地图
  4. 基于Winform、WPF等的客户端文件下载
  5. JavaScript中sort方法的一个坑(leetcode 179. Largest Number)
  6. (六)6.15 Neurons Networks Deep Belief Networks
  7. show/hide
  8. 高效的TCP消息发送组件
  9. CSS美化 input type=file 兼容各个浏览器(转)
  10. NSTimer 详细设置
  11. 使用URLConnection提交请求
  12. TCP/UDP简介
  13. 学习ASP.NET Core Razor 编程系列五——Asp.Net Core Razor新建模板页面
  14. centos6.5安装Mysql5.6及更改密码
  15. 京东饭粒捡漏V1.15
  16. 20165231 实验一 Java开发环境的熟悉
  17. #include<bits/stdc++.h>的使用
  18. C# dynamic类型报错:“object”不包含“xxx”的定义
  19. 【Centos】centos查看磁盘使用情况
  20. conductor 事件处理程序

热门文章

  1. scala&&spark学习参考文章
  2. 函数动态参数 *args **kwargs
  3. STL—— 容器(vector)的数据写入、修改和删除
  4. 项目中对获取的数据进行下载成Excel表格
  5. sqli-labs less38-53(堆叠注入 order by之后相关注入)
  6. 在Linux下下载RPM包
  7. Web服务器-并发服务器-多进程(3.4.1)
  8. C#中的深度学习(二):预处理识别硬币的数据集
  9. python菜鸟教程学习:数据结构
  10. Python利用openpyxl带格式统计数据(2)- 处理mysql数据