首页 > 数据库 > MySQL > 正文

MYSQL中锁的模式与类别有哪些

2024-07-24 12:33:41
字体:
来源:转载
供稿:网友
  在日常开发工作中,我们几乎需要天天与数据库打交道,作为一名只会CRUD的SQL BOY,除了每天用mybatis-generator自动生成DAO层代码之外,我们几乎不用去care数据库中如何处理并发请求,但是突然某一天MYSQL数据库告警了,出现了死锁,我们的内心慌的一匹,不禁想问:这不就是个普通查询吗,咋还锁起来了?
 
  读锁是某个事务(比如事务A)在进行读取操作(比如读一张表或者读取某一行)时创建出来的锁,其他的事务可以并发地读取这些数据(被加了锁的),但是不能修改这些数据(除非持有锁的用户已经释放锁)。
 
  事务A对数据加上读锁之后,其他事务依然可以对其添加读锁(共享),但是不能添加写锁。
 
  普通查询在隔离级别为 serializable 会给记录加S锁。但这也取决于场景:非事务读(auto-commit)在 Serializable 隔离级别下,无需加锁;
 
  Serializable隔离级别时:如果查询条件为唯一索引且是唯一等值查询时:是在该条记录上加S锁;非唯一条件查询(查询会扫描到多条记录时):记录本身+记录的间隙(需要具体分析间隙的范围),加S锁;
 
  select … in share mode,会给记录加S锁,但是根据隔离级别的不同,加锁的行为有所不同:
 
  RC隔离级别:是在记录上加S锁。RR/Serializable隔离级别:如果查询条件为唯一索引且是唯一等值查询时:是在该条记录上加S锁;非唯一条件查询(查询会扫描到多条记录时):记录本身+记录的间隙(需要具体分析间隙的范围),加S锁;
 
  通常insert操作是不加锁的,但如果在插入或更新记录时,检查到 duplicate key(或者有一个被标记删除的duplicate key),对于普通的insert/update,会加S锁,而对于类似replace into或者insert … on duplicate 这样的SQL语句加的是X锁。
 
  insert … select 插入数据时,会对 select 的表上扫描到的数据加S锁;
 
  外键检查:当我们删除一条父表上的记录时,需要去检查是否有引用约束,这时候会扫描子表上对应的记录,并加上S锁。

(编辑:武林网)

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表