行锁页面锁与表锁
Posted yanze
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了行锁页面锁与表锁相关的知识,希望对你有一定的参考价值。
按锁定粒度:表锁、页面锁、行锁
存储引擎支持情况:
在具体说明之前得明白什么是死锁,什么是锁冲突
死锁: 多个进程互相等待对方锁的释放
锁冲突:一个进程等待另一个进程释放需要的锁
行锁
粒度小,开销大,加锁慢,会产生死锁,发生锁冲突的概率最低,并发度也最高。
备注:在InnoDB中,锁是逐步获得的,这可能造成多个进程互相等待的尴尬局面,造成了死锁。
分类:共享锁 排他锁
备注: 共享锁又称读锁,排他锁又称写锁
表锁
粒度大,开销小,加锁快,不会出现死锁,发出锁冲突的概率最高,并发度最低。
备注:MyISAM总是一次性获得所需的全部锁,要么全部满足,要么全部等待,因此不会产生死锁。
分类:表共享锁
、表排他锁
页面锁
各方面介于行锁与表锁之间
以上是关于行锁页面锁与表锁的主要内容,如果未能解决你的问题,请参考以下文章
mysql的行锁与表锁(select* .... FOR UPDATE)