1. 表读锁
lock table tablename read;
例如:
从上图中可以看到,当给表a加了读锁之后,该进程本身对表a是可读的,但是不可写,再看在另外一个进程中:
在另外一个进程中表a也是可读的,但是写被延迟了等待中
一句话:当给表加了读锁之后,加锁的该进程和其余进程或者说用户,都有读的权限,都没有写的权限,或者被禁止了,或者被延迟了
2. 表写锁
lock table tablename write;
可以看到,当表a在一个进程中被写锁了,该进程对表a既有读的权限,又有写的权限。
在另外一个进程中:
可以看到,其他的进程既没有读的权限,又没有写的权限
简而言之:当表在一个进程中被写锁时,该进程本身同时拥有对该表的读写权限,而其余的进程对该表则既无读的权限,又无写的权限。
原文链接:http://blog.csdn.net/yy20071313/article/details/31551385