MySQL的lock tables和unlock tables的用法

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下測試經過。

相關文章
相關標籤/搜索