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

MySQL-锁篇

文章目录

  • 表级锁和行级锁了解吗?有什么区别?
  • 行级锁使用有什么注意事项?
  • InnoDB有哪几类行锁?
  • 共享锁和排他锁是什么?
  • 意向锁有什么用?

锁是一种常见的并发事务的控制方式

表级锁和行级锁了解吗?有什么区别?

表级锁:MySQL中锁定粒度最大的一种锁(全局锁除外),针对非索引字段加的锁,不会出现死锁,不过,触发锁冲突的概率最高,高并发下效率极低
行级锁:MySQL中锁定粒度最小的一种锁,是针对索引字段加的锁,只针对当前操作记录的行加的锁

行级锁使用有什么注意事项?

行锁是针对索引字段加的锁,表级锁是针对非索引字段的锁,当我们执行update,delete语句时,如果where条件没有命中唯一索引或者索引失效的话,就会导致扫描全表对表中所有行记录进行加锁

InnoDB有哪几类行锁?

  1. 记录锁:锁定单个行记录的锁
  2. 间隙锁:锁定索引记录间隙(不含该记录)
  3. 临键锁:记录锁+间隙锁,同时锁住数据,并锁住间隙

共享锁和排他锁是什么?

不论表级锁和行级锁,都存在共享锁(S锁)和排他锁(X锁)两类
共享锁:读锁,事务在读取记录时获取共享锁,允许多个事务同时获取
排他锁:写锁/独占锁,事务在修改记录时获取排他锁,不允许多个事务同时获取
排他锁与其他任何锁都不兼容,共享锁只与共享锁兼容

S 锁X 锁
S 锁不冲突冲突
X 锁冲突冲突

意向锁有什么用?

用到表锁时,快速判断一个表是否有行锁
意向锁是表级锁,分为两类:

  • 意向共享锁(IS锁):事务有意向对表中某些记录添加共享锁(S锁),加共享锁之前必须先获取该表的IS锁
  • 意向排他锁(IX锁):事务有意向对表中某些记录添加排他锁(X锁),加排它锁之前必须先获取该表的IX锁

意向锁之间是相互兼容的

IS 锁IX 锁
IS 锁兼容兼容
IX 锁兼容兼容

意向锁和共享锁和排他锁互斥兼容情况

IS 锁IX 锁
S 锁(读锁)兼容互斥
X 锁(写锁)互斥互斥
http://www.lryc.cn/news/340314.html

相关文章:

  • 滤波器笔记(杂乱)
  • 【ARFoundation自学01】搭建AR框架,检测平面点击位置克隆物体
  • .Net ajax 接收参数
  • 智能零售:引领购物新时代
  • 【AIGC】AIGC在虚拟数字人中的应用:塑造未来互动体验的革新力量
  • 电机控制器电路板布局布线参考指导(五)
  • Python医院挂号脚本
  • LabVIEW光学探测器板级检测系统
  • 女上司问我:误删除PG百万条数据,可以闪回吗?
  • HarmonyOS4-数据持久化
  • 深度学习的社交网络:用户行为分析
  • Python 使用 pip 安装 matplotlib 模块(精华版)
  • UOS系统-mips架构---Java环境安装
  • Java——二叉树
  • 数据仓库—维度建模—事实表设计
  • 《系统架构设计师教程(第2版)》第9章-软件可靠性基础知识-05-软件可靠性测试
  • uni-app vue3 setup 如何使用 onShow
  • linux学习:进程(新建+运行某文件+退出处理函数+等待)
  • Leetcode. 12 整数转罗马数字
  • 【uniapp】request请求函数封装,token、成功、失败等
  • 0基础如何入门编程?
  • Go 单元测试基本介绍
  • uniapp 上传视频到阿里云之后回显视频获取视频封面
  • 使用undetected-chromedriver遇到的问题及解决方法,以及它使用SOCKS代理的问题
  • Hadoop入门学习路线
  • Python中的设计模式与最佳实践【第166篇—设计模式】
  • Python赋能AI数据分析开启人工智能新时代
  • TP5使用group报错:1055 Expression #1 of SELECT list is not in GROUP
  • SQL-DML数据操纵语言(Oracle)
  • springboot+axios传参问题