mysql 读写锁

1. 表读锁

lock table tablename read;

例如:

 

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

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

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

 

2. 表写锁

lock table tablename write;

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

 

在另外一个进程中:

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

 

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

 

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

 

posted @ 2017-08-01 09:29  nele  阅读(529)  评论(0编辑  收藏  举报