MySQL的lock tables和unlock tables的用法

來源:互聯網
上載者:User

標籤:

早就聽說lock tablesunlock tables這兩個命令,從字面也大體知道,前者的作用是鎖定表,後者的作用是解除鎖定。但是具體如何用,怎麼用,不太清楚。今天詳細研究了下,總算搞明白了2者的用法。

lock tables 命令是為當前線程鎖定表.這裡有2種類型的鎖定,一種是讀鎖定,用命令 lock tables tablename read; 另外一種是寫鎖定,用命令lock tables tablename write.下邊分別介紹:

1. lock table 讀鎖定

如果一個線程獲得在一個表上的read鎖,那麼該線程和所有其他線程只能從表中讀資料,不能進行任何寫操作。

下邊我們測試下,測試表為user表。

不同的線程,可以通過開多個命令列MySQL用戶端來實現:

注意: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類型的表。

參考如下測試:

MySQL的lock tables和unlock tables的用法

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.