lock tables 命令是爲當前線程鎖定表.這裏有2種類型的鎖定,一種是讀鎖定,用命令 lock tables tablename read;另一種是寫鎖定,用命令lock tables tablename write.下邊分別介紹:mysql
1. lock table 讀鎖定sql
若是一個線程得到在一個表上的read鎖,那麼該線程和全部其餘線程只能從表中讀數據,不能進行任何寫操做。測試
下邊咱們測試下,測試表爲user表。spa
不一樣的線程,能夠經過開多個命令行MySQL客戶端來實現:.net
時刻點命令行 |
線程A(命令行窗口A)線程 |
線程B(命令行窗口B)事務 |
|
|
|
1ci |
mysql> lock tables user read;資源 Query OK, 0 rows affected (0.00 sec) mysql> 對user表加讀鎖定。 |
|
2 |
mysql> select * from user; +------+-----------+ | id | name | +------+-----------+ | 22 | abc | | 223 | dabc | | 2232 | dddabc | | 45 | asdsagd | | 23 | ddddddddd | +------+-----------+ 5 rows in set (0.00 sec) mysql> 本身的讀操做未被阻塞 |
mysql> select * from user; +------+-----------+ | id | name | +------+-----------+ | 22 | abc | | 223 | dabc | | 2232 | dddabc | | 45 | asdsagd | | 23 | ddddddddd | +------+-----------+ 5 rows in set (0.00 sec) mysql> 其餘線程的讀也未被阻塞 |
3 |
mysql> insert into user values(12,'test'); ERROR 1099 (HY000): Table 'user' was locked with a READ lock and can't be updated mysql> 發現本線程的寫操做被阻塞 |
mysql> insert into user values(22,'2test'); 發現沒有任何反應,一直等待中,說明沒有獲得寫鎖定,一直處於等待中。 |
4 |
mysql> unlock tables; Query OK, 0 rows affected (0.00 sec) mysql> 釋放讀鎖定。 |
mysql> insert into user values(22,'ddd'); Query OK, 1 row affected (1 min 27.25 sec) mysql> 在線程A釋放讀鎖後,線程B得到了資源,剛纔等待的寫操做執行了。 |
5 |
mysql> lock tables user read local; Query OK, 0 rows affected (0.00 sec) mysql> 得到讀鎖定的時候增長local選項。 |
mysql> insert into user values(2,'b'); Query OK, 1 row affected (0.00 sec) mysql> 發現其餘線程的insert未被阻塞。 |
6 |
|
mysql> update user set name = 'aaaaaaaaaaaaaaaaaaaaa' where id = 1; 可是其餘線程的update操做被阻塞了。 |
注意:user表必須爲Myisam表,以上測試才能所有OK,若是user表爲innodb表,則lock tables user read local命令可能沒有效果,也就是說,若是user表爲innodb表,第6時刻將不會被阻塞,這是由於INNODB表是事務型的,對於事務表,例如InnoDB和BDB,--single-transaction是一個更好的選項,由於它不根本須要鎖定表
2. lock table 寫鎖定
若是一個線程在一個表上獲得一個 WRITE 鎖,那麼只有擁有這個鎖的線程能夠從表中讀取和寫表。其它的線程被阻塞。
寫鎖定的命令:lock tables user write.user表爲Myisam類型的表。
參考以下測試:
時刻點 |
線程A(命令行窗口A) |
線程B(命令行窗口B) |
|
|
|
1 |
mysql> lock tables user write; Query OK, 0 rows affected (0.00 sec) 對user表加寫鎖定。 |
|
2 |
mysql> select * from user; +----+-----------------------+ | id | name | +----+-----------------------+ | 1 | aaaaaaaaaaaaaaaaaaaaa | | 2 | b | +----+-----------------------+ 2 rows in set (0.00 sec) 本身能夠繼續進行讀操做 |
mysql> select * from user; 其餘線程讀操做被阻塞。 |
3 |
mysql> unlock tables ; Query OK, 0 rows affected (0.00 sec) 釋放鎖定。 |
|
4 |
mysql> select * from user; +----+-----------------------+ | id | name | +----+-----------------------+ | 1 | aaaaaaaaaaaaaaaaaaaaa | | 2 | b | +----+-----------------------+ 2 rows in set (32.56 sec) 其餘線程得到資源,能夠讀數據了。 |
以上全部結果均在MySQL 5.4.3下測試經過。