mysql 读写锁

时间:2023-03-09 08:58:42
mysql 读写锁

1. 表读锁

lock table tablename read;

例如:

mysql 读写锁

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

mysql 读写锁

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

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

 

2. 表写锁

lock table tablename write;

mysql 读写锁

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

在另外一个进程中:

mysql 读写锁

mysql 读写锁

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

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

原文链接:http://blog.****.net/yy20071313/article/details/31551385