当前位置: 首页 > news >正文

Mysql的锁

表级锁、行级锁、全局锁

表级锁:锁住一整张表,针对非索引字段加的锁,sql没有用到索引就会使用全局锁,性能较低。

行级锁:针对索引字段加的锁,会锁住一行记录,并发性能高。

全局锁:锁住一整个库,让数据库处于只读状态,一般在数据备份时用到。

当update、delete的时候没有命中唯一索引或者索引失效,会走全表扫描加上表锁,性能很低。

共享锁和排它锁

表锁和行锁都由共享锁和排它锁。

共享锁又称读锁,允许多个事务同时读取数据。
排它锁又称写锁,在修改操作时会获取排他锁,排它锁之间是互斥的,同时只允许一个事务获取。

共享锁之间不互斥,共享锁与排它锁互斥,排它锁之间是互斥的。

意向锁

意向锁是表锁,主要作用是在我们需要对整张表加表锁的时候,由于表锁和行锁是互斥的,如果去一行一行的检查有没有行锁,那么效率很低,所以当我们去加行锁的时候同时会加上一个意向锁,当要加表锁的时候检查到有意向锁,就知道某行记录加了行锁,也就不用一行行的去检查了。

记录锁、间隙锁、临键锁

它们都是行锁。

记录锁:对单个记录加锁。
间隙锁:锁定记录之间的间隙,不包括记录。
临键锁:记录锁+间隙锁,锁定一个范围,包括记录本身。主要是为了解决幻读问题。

临键锁是RR隔离级别下用于防止幻读的措施,当select...for update,select...for lock in share mode 去范围查询时,或者查询条件是非唯一索引查出多行记录时就会产生临键锁,防止插入导致幻读。

相关文章:

  • lodash 学习笔记/使用心得
  • 2.企业级AD活动目录架构与设计原则实战指南
  • C# 调用 VITS,推理模型 将文字转wav音频net8.0 跨平台
  • Python FastApi(3):路径参数
  • 使用AI一步一步实现若依前端(16)
  • Elasticsearch 中的数据分片问题
  • Deepseek浪潮下,汽车芯片开启“大变局”,谁将领跑?
  • 进程地址空间(上)【Linux】
  • libc.so.6: version `GLIBC_2.29‘ not found, 如何解决这个错误
  • Python `is` 关键字深度解析
  • CCF-CSP认证 202209-2何以包邮?
  • 文件上传的小点总结
  • JVM如何处理Java中的精度转换: 从源码到字节码
  • 查看自己的公有ip
  • 深度解析 | Android 13 Launcher3分页指示器改造:横线变圆点实战指南
  • 玄机-第四章 windows实战-emlog的测试报告
  • 初识Brainstorm(matlab)
  • JSON在AutoCAD二次开发中应用场景及具体案例
  • PHP 应用后台模块SessionCookieToken身份验证唯一性
  • 2025.3.17-2025.3.23学习周报
  • 解读|降准叠加政策利率、公积金贷款利率、结构性政策工具利率全线下调,影响有多大?
  • 玉渊谭天丨是自保还是自残?八个恶果透视美国征收100%电影关税
  • 世锦赛决赛今夜打响,斯诺克运动需要赵心童创造历史
  • 长三角铁路今日预计发送旅客398万人次,客流持续保持高位运行
  • 熬夜又不想伤肝?方法只有一个
  • 五一假期多地政府食堂对外开放:部分机关食堂饭菜“秒没”