MYSQL:索引与锁表范围简述-CSDN博客

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

一、聚簇索引原则

当有主键索引时选择主键索引如果没有主键索引选择第一个的unique索引如果都没有就选择隐藏生成的ROW_ID。

二、加锁原则

来自知乎MySQL探秘(七):InnoDB行锁算法 - 知乎 (zhihu.com)

  • 在不通过索引条件查询时InnoDB 会锁定表中的所有记录。所以如果考虑性能WHERE语句中的条件查询的字段都应该加上索引。这是由于查询时没有通过索引操作会扫描一遍全表的ROW_ID相当于是加上了表锁。
  • InnoDB通过索引来实现行锁而不是通过锁住记录。因此当操作的两条不同记录拥有相同的索引时也会因为行锁被锁而发生等待。
  • 由于InnoDB的索引机制数据库操作使用了主键索引InnoDB会锁住主键索引使用非主键索引时InnoDB会先锁住非主键索引再锁定主键索引。例如锁住唯一索引主键索引也被锁住了。
  • 当查询的索引是唯一索引(不存在两个数据行具有完全相同的键值)时InnoDB存储引擎会将Next-Key Lock降级为Record Lock即只锁住索引本身而不是范围。
  • InnoDB对于辅助索引有特殊的处理不仅会锁住辅助索引值所在的范围还会将其下一键值加上Gap LOCK。
  • InnoDB使用Next-Key Lock机制来避免Phantom Problem幻读问题。

三、补充

对于原则的后几点我还不是很清楚等学习了相关课程后再进行记录。

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6
标签: mysql

“MYSQL:索引与锁表范围简述-CSDN博客” 的相关文章