mysql的独占锁和共享锁
当有多个事务同时更新一条sql时,mysql是如何处理的呢?很显然,使用加锁的方式,一个事务获得了锁,进行操作,其他事务排队一个个等着,等当前这个事务执行完释放锁,其他事务获取锁取到锁的进行操作。这里的锁就是独占锁,也就是X锁。
那么如果有查询这一行数据时,是要加锁吗?不是的,mysql为了提高性能,读的时候使用mvcc机制,通过ReadView,查询undo log版本链,获取到自己能查询到的版本数据。读与更新同时进行,不互斥,性能就提高了。
共享锁又是什么呢?mysql里叫共享锁为S锁,通 过手动执行select * from table lock in share mode来加共享锁。加了共享锁,还能加独占锁吗?不能的,共享锁和独占锁是互斥的。不过共享锁和共享锁不互斥,也就是加了一个共享锁,还可以再加另一个共享锁。
独占锁 | 共享锁 | |
独占锁 | 互斥 | 互斥 |
共享锁 | 互斥 | 不互斥 |
但平时我们是很少去手动加共享锁的,一般更新时加独占锁就够了。 另外执行select * from table for update也会加独占锁。
相关推荐
wensonlee 2020-06-12
webliyang 2020-05-27
langyue 2020-05-19
mengyue 2020-04-30
pengpengflyjhp 2020-03-07
tlsmile 2020-02-15
QianChia 2020-01-24
tangjianft 2020-01-05
wensonlee 2019-12-04
喝绿茶的猫 2018-06-14
门门雨 2019-07-01
sqlican 2019-07-01
yongyoumengxiang 2019-06-28
liwenbocsu 2019-06-28
了缺 2019-06-28
InitJ 2019-06-28
YangSunshine 2019-06-27
dedebug 2019-06-27
数据库之扑朔迷离 2019-06-27