mysql 读写锁的理解

来源:互联网 发布:mysql文件的编码 编辑:程序博客网 时间:2024/06/04 18:25

mysql 中有各种类型的锁,我说一下个人对于表级的读写锁的浅显理解

1. 表读锁

lock table tablename read;

例如:


从上图中可以看到,当给表a加了读锁之后,该进程本身对表a是可读的,但是不可写,再看在另外一个进程中:


在另外一个进程中表a也是可读的,但是写被延迟了等待中

一句话:当给表加了读锁之后,加锁的该进程和其余进程或者说用户,都有读的权限,都没有写的权限,或者被禁止了,或者被延迟了


2. 表写锁

lock table tablename write;


可以看到,当表a在一个进程中被写锁了,该进程对表a既有读的权限,又有写的权限。


在另外一个进程中:



可以看到,其他的进程既没有读的权限,又没有写的权限


简而言之:当表在一个进程中被写锁时,该进程本身同时拥有对该表的读写权限,而其余的进程对该表则既无读的权限,又无写的权限。




0 0
原创粉丝点击