MySQL行级锁、表级锁、页级锁
来源:互联网 发布:ubuntu 设置密码 编辑:程序博客网 时间:2024/06/06 17:57
行级锁
行级锁是Mysql中锁定粒度最细的一种锁,表示只针对当前操作的行进行加锁。行级锁能大大减少数据库操作的冲突。其加锁粒度最小,但加锁的开销也最大。行级锁分为共享锁 和 排他锁。
特点:开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高。表级锁
表级锁是MySQL中锁定粒度最大的一种锁,表示对当前操作的整张表加锁,它实现简单,资源消耗较少,被大部分MySQL引擎支持。最常使用的MYISAM与INNODB都支持表级锁定。表级锁定分为表共享读锁(共享锁)与表独占写锁(排他锁)。
特点:开销小,加锁快;不会出现死锁;锁定粒度大,发出锁冲突的概率最高,并发度最低。页级锁
页级锁是MySQL中锁定粒度介于行级锁和表级锁中间的一种锁。表级锁速度快,但冲突多,行级冲突少,但速度慢。所以取了折衷的页级,一次锁定相邻的一组记录。BDB支持页级锁
特点:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般MySQL常用存储引擎与锁机制对应
引擎 行级锁 表级锁 页级锁 默认 MyISAM 支 持 不支持 不支持 表级锁 InnoDB 支 持 支 持 不支持 索引条件检索:行级锁,否则:表级锁 BDB 不支持 支 持 支 持 页级锁Innodb中的行锁与表锁
前面提到过,在Innodb引擎中既支持行锁也支持表锁,那么什么时候会锁住整张表,什么时候或只锁住一行呢?
InnoDB行锁是通过给索引上的索引项加锁来实现的,这一点MySQL与Oracle不同,后者是通过在数据块中对相应数据行加锁来实现的。InnoDB这种行锁实现特点意味着:只有通过索引条件检索数据,InnoDB才使用行级锁,否则,InnoDB将使用表锁!
在实际应用中,要特别注意InnoDB行锁的这一特性,不然的话,可能导致大量的锁冲突,从而影响并发性能。
在不通过索引条件查询的时候,InnoDB 确实使用的是表锁,而不是行锁。
由于 MySQL 的行锁是针对索引加的锁,不是针对记录加的锁,所以虽然是访问不同行 的记录,但是如果是使用相同的索引键,是会出现锁冲突的。应用设计的时候要注意这一点。
当表有多个索引的时候,不同的事务可以使用不同的索引锁定不同的行,另外,不论 是使用主键索引、唯一索引或普通索引,InnoDB 都会使用行锁来对数据加锁。
即便在条件中使用了索引字段,但是否使用索引来检索数据是由 MySQL 通过判断不同 执行计划的代价来决定的,如果 MySQL 认为全表扫 效率更高,比如对一些很小的表,它 就不会使用索引,这种情况下 InnoDB 将使用表锁,而不是行锁。因此,在分析锁冲突时, 别忘了检查 SQL 的执行计划,以确认是否真正使用了索引。行级锁与死锁
MyISAM中是不会产生死锁的,因为MyISAM总是一次性获得所需的全部锁,要么全部满足,要么全部等待。而在InnoDB中,锁是逐步获得的,就造成了死锁的可能。
在MySQL中,行级锁并不是直接锁记录,而是锁索引。索引分为主键索引和非主键索引两种,如果一条sql语句操作了主键索引,MySQL就会锁定这条主键索引;如果一条语句操作了非主键索引,MySQL会先锁定该非主键索引,再锁定相关的主键索引。 在UPDATE、DELETE操作时,MySQL不仅锁定WHERE条件扫描过的所有索引记录,而且会锁定相邻的键值,即所谓的next-key locking。
当两个事务同时执行,一个锁住了主键索引,在等待其他相关索引。另一个锁定了非主键索引,在等待主键索引。这样就会发生死锁。
发生死锁后,InnoDB一般都可以检测到,并使一个事务释放锁回退,另一个获取锁完成事务。
有多种方法可以避免死锁,这里只介绍常见的三种- 如果不同程序会并发存取多个表,尽量约定以相同的顺序访问表,可以大大降低死锁机会。
- 在同一个事务中,尽可能做到一次锁定所需要的所有资源,减少死锁产生概率;
- 对于非常容易产生死锁的业务部分,可以尝试使用升级锁定颗粒度,通过表级锁定来减少死锁产生的概率;
- MySQL行级锁、表级锁、页级锁
- MySQL行级锁、表级锁、页级锁
- MySQL行级锁、表级锁、页级锁
- MySQL行级锁、表级锁、页级锁
- MySQL表级锁,行级锁和页级锁
- MySQL行级锁,表级锁,页级锁详解
- Mysql行级锁/页级锁/表级锁详解
- MySQL中的行级锁,表级锁,页级锁
- mysql中的行级锁,表级锁,页级锁
- MySQL中的行级锁,表级锁,页级锁
- MySQL中的行级锁,表级锁,页级锁
- MySQL中的行级锁,表级锁,页级锁
- mysql行级锁|表级锁|页级锁详解
- MySQL行级锁、表级锁、页级锁详细介绍
- MySQL行级锁、表级锁、页级锁详细介绍
- MySQL行级锁、表级锁、页级锁详细介绍
- MySQL行级锁、表级锁、页级锁详细介绍
- MySQL行级锁、表级锁、页级锁详细介绍
- springboot集成hibernate-jpa方式
- protothread_简介
- 开发中泛型使用注意事项
- 算法
- 使用@RequestMapping 定义处理器函数-支持的形参类型
- MySQL行级锁、表级锁、页级锁
- Frogs (hdu5514)——2015ACM/ICPC亚洲区沈阳站(容斥定理)
- PINDEL检测结构变异
- 主题三 编译过程介绍---- 16.宏定义与使用分析
- 【已解决】linux redhat 6 如何打开防火墙中的某个端口?例如:5900端口
- Java静态代码块和构造块(面试时候能用到,开发一般不会用到)
- android binder机制,注册系统服务---结果返回
- Unity通过字符串“class”调用此类class的方法
- 安卓SDK接入Unity