MySQL锁机制分为表级锁和行级锁,本文就和大家分享一下我对mysql中行级锁中的共享锁与排他锁进行分享交流。
共享锁又称为读锁,简称S锁,顾名思义,共享锁就是多个事务对于同一数据可以共享一把锁,都能访问到数据,但是只能读不能修改。
排他锁又称为写锁,简称X锁,顾名思义,排他锁就是不能与其他所并存,如一个事务获取了一个数据行的排他锁,其他事务就不能再获取该行的其他锁,包括共享锁和排他锁,但是获取排他锁的事务是可以对数据就行读取和修改。
对于共享锁大家可能很好理解,就是多个事务只能读数据不能改数据,对于排他锁大家的理解可能就有些差别,我当初就犯了一个错误,以为排他锁锁住一行数据后,其他事务就不能读取和修改该行数据,其实不是这样的。排他锁指的是一个事务在一行数据加上排他锁后,其他事务不能再在其上加其他的锁。mysql InnoDB引擎默认的修改数据语句,update,delete,insert都会自动给涉及到的数据加上排他锁,select语句默认不会加任何锁类型,如果加排他锁可以使用select ...for update语句,加共享锁可以使用select ... lock in share mode语句。所以加过排他锁的数据行在其他事务种是不能修改数据的,也不能通过for update和lock in share mode锁的方式查询数据,但可以直接通过select ...from...查询数据,因为普通查询没有任何锁机制。
共享锁:可以加共享锁,不能加排它锁
排它锁:不能加共享锁,不能加排它锁
说了这么多,咱们来看下以下简单的例子:
简单查询,加了排他锁,没有commit,锁就不会释放,可以查询数据
打开新的窗口,同样使用共享锁查询,发现一直在加载,使用排它锁查询,依然在加载
图1. 加排它锁
图2.加共享锁
图3.普通查询可以查询,因为普通查询没有加任何锁
同样的道理,可以来看先加了共享锁之后,再携带共享锁,可以查询,排它锁则不行
图1.加了排它锁,一直在加载,无法查询
图2.加了共享锁,可以成功查询
共享锁:可以加共享锁,不能加排它锁
排它锁:不能加共享锁,不能加排它锁
转自:http://blog.csdn.net/c466254931/article/details/53463596
本文转自布拉君君 51CTO博客,原文链接:http://blog.51cto.com/5148737/1962032,如需转载请自行联系原作者