使用者工具

網站工具


database:mysql:locktable

差異處

這裏顯示兩個版本的差異處。

連向這個比對檢視

Both sides previous revision 前次修改
下次修改
前次修改
database:mysql:locktable [2014/01/11 09:03]
ali88
database:mysql:locktable [2014/01/11 14:49] (目前版本)
ali88
行 6: 行 6:
 ======Lock Tables 特性與指令====== ======Lock Tables 特性與指令======
 在做以下解說之前,​先在MySQL的test資料庫建立一個名為QQ的資料表並插入一些資料。(目前在 MySQL 5.1.71 下作業)<​code>​mysql>​ create table QQ(id int ,data char(10));</​code><​code>​mysql>​ insert into QQ(id,​data)values(1,'​AA'​),​(2,'​BB'​),​(3,'​CC'​),​(4,'​DD'​),​(5,'​EE'​),​(6,'​FF'​),​(7,'​GG'​),​(8,'​HH'​),​(9,'​II'​),​(10,'​JJ'​);</​code>​ 在做以下解說之前,​先在MySQL的test資料庫建立一個名為QQ的資料表並插入一些資料。(目前在 MySQL 5.1.71 下作業)<​code>​mysql>​ create table QQ(id int ,data char(10));</​code><​code>​mysql>​ insert into QQ(id,​data)values(1,'​AA'​),​(2,'​BB'​),​(3,'​CC'​),​(4,'​DD'​),​(5,'​EE'​),​(6,'​FF'​),​(7,'​GG'​),​(8,'​HH'​),​(9,'​II'​),​(10,'​JJ'​);</​code>​
-===Lock tables QQ read===+==== Lock tables QQ read ===
 +  * 所有session(connection id)可以讀取QQ資料表,​但無法更新或寫入(包括建立此 lock tables的session)。 
 + 
 + 
 +^Time  ^session1 ​                                ​^session2 ​            ^ 
 +|      |mysql>​lock tables QQ read;               | | 
 +|      |mysql>​select * from QQ where id=1;  (OK)     ​|mysql>​select * from QQ where id=2; (OK)| 
 +|      |mysql>​delete from QQ where id=1; (ERROR 1099) |                                      | 
 +|      |                                              |mysql>​delete ​ from QQ where id=2; (在read Queue中 等待)| 
 +|      |mysql>​unlock tables ;​|mysql>​Query OK, 1 row affected (剛在等待的delete ​ from QQ where id=2被執行);​| 
 + 
 +==== Lock tables QQ write ==== 
 +  * 建立此 lock tables write 的session可以讀取並且也可寫入;​其他session不可寫入,​也不可讀取。 
 + 
 + 
 +^Time  ^session1 ​                                ​^session2 ​            ^ 
 +|      |mysql>​lock tables QQ write; ​              | | 
 +|      |mysql>​select * from QQ where id=1;  (OK)  | | 
 +|      |mysql>​delete from QQ where id=1;    (OK)      | | 
 +|      |                                          |mysql>​select * from QQ where id=10;​(在write Queue中 等待)| 
 +|      |mysql>​unlock tables; ​                     |mysql>​Query OK, 1 row affected (剛在等待的select * from QQ where id=10;​被執行);​| 
 + 
 +====Lock table read/​write優先權==== 
 +  * Lock tables write 比 Lock tables read 優先權高 
 + 
 +^Time  ^session1 ​                                ​^session2 ​            ​^session3^ 
 +|      |mysql>​lock tables QQ write; ​              ​| ​                   |        | 
 +|      |                                          |mysql>​lock tables QQ read;​(在write Queue中 等待) ​                   |        | 
 +|      |              |                    |mysql>​lock tables QQ write;​(在write Queue中 等待) ​        | 
 +|      |mysql>​unlock tables; ​              ​| ​                   |mysql>​Query OK, 0 rows affected (剛在等待的 lock tables QQ write;​被執行) ​      | 
 +|      |              |mysql>​Query OK, 0 rows affected (剛在等待的 lock tables QQ read;​被執行) ​                   |mysql>​unlock tables; ​       | 
 +|      |               ​|mysql>​unlock tables; ​                   |        | 
 + 
 + 
 +====Lock tables QQ LOW_PRIORITY write(此項指令在 MySQL 5.5.x以上式忽已經失效了)==== 
 +  * 降低write lock 優先權 使  read lock 優先權提高 
 + 
 +^Time  ^session1 ​                                ​^session2 ​            ​^session3^ 
 +|      |mysql>​lock tables QQ write; ​              ​| ​                   |        | 
 +|      |                                          |mysql>​lock tables QQ read;​(在write Queue中 等待) ​                   |        | 
 +|      |              |                    |mysql>​lock tables QQ LOW_PRIORITY write;​(在write Queue中 等待) ​        | 
 +|      |mysql>​unlock tables; ​              ​|mysql>​Query OK, 0 rows affected (剛在等待的 lock tables QQ read;​被執行) ​                   |       | 
 +|      |              |mysql>​unlock tables; ​                   |       ​mysql>​Query OK, 0 rows affected (剛在等待的 lock tables QQ LOW_PRIORITY write;​被執行) | 
 +|      |               ​| ​                  ​|mysql>​unlock tables; ​        | 
 + 
 + 
 ======參考資料====== ======參考資料======
   * [[http://​pcclass.cc.nthu.edu.tw/​nuke/​dbms.php?​filename=class2-2.html|鎖定資料表 (Lock)]]   * [[http://​pcclass.cc.nthu.edu.tw/​nuke/​dbms.php?​filename=class2-2.html|鎖定資料表 (Lock)]]
   * [[http://​xyz.cinc.biz/​2013/​04/​mysql-lock-tables.html|MySQL 鎖定資料表 (LOCK TABLES) ]]   * [[http://​xyz.cinc.biz/​2013/​04/​mysql-lock-tables.html|MySQL 鎖定資料表 (LOCK TABLES) ]]
database/mysql/locktable.1389431019.txt.gz · 上一次變更: 2014/01/11 09:03 由 ali88