MySQL中的共享鎖與排他鎖

MySQL中的行級鎖,表級鎖,頁級鎖中介紹過,行級鎖是Mysql中鎖定粒度最細的一種鎖,行級鎖能大大減小數據庫操做的衝突。行級鎖分爲共享鎖和排他鎖兩種,本文將詳細介紹共享鎖及排他鎖的概念、使用方式及注意事項等。php

共享鎖(Share Lock)

共享鎖又稱讀鎖,是讀取操做建立的鎖。其餘用戶能夠併發讀取數據,但任何事務都不能對數據進行修改(獲取數據上的排他鎖),直到已釋放全部共享鎖。html

若是事務T對數據A加上共享鎖後,則其餘事務只能對A再加共享鎖,不能加排他鎖。獲准共享鎖的事務只能讀數據,不能修改數據。linux

用法

SELECT ... LOCK IN SHARE MODE;sql

在查詢語句後面增長LOCK IN SHARE MODE,Mysql會對查詢結果中的每行都加共享鎖,當沒有其餘線程對查詢結果集中的任何一行使用排他鎖時,能夠成功申請共享鎖,不然會被阻塞。其餘線程也能夠讀取使用了共享鎖的表,並且這些線程讀取的是同一個版本的數據。數據庫

排他鎖(eXclusive Lock)

排他鎖又稱寫鎖,若是事務T對數據A加上排他鎖後,則其餘事務不能再對A加任任何類型的封鎖。獲准排他鎖的事務既能讀數據,又能修改數據。併發

用法

SELECT ... FOR UPDATE;spa

在查詢語句後面增長FOR UPDATE,Mysql會對查詢結果中的每行都加排他鎖,當沒有其餘線程對查詢結果集中的任何一行使用排他鎖時,能夠成功申請排他鎖,不然會被阻塞。.net

意向鎖

InnoDB還有兩個表鎖:線程

意向共享鎖(IS):表示事務準備給數據行加入共享鎖,也就是說一個數據行加共享鎖前必須先取得該表的IS鎖code

意向排他鎖(IX):相似上面,表示事務準備給數據行加入排他鎖,說明事務在一個數據行加排他鎖前必須先取得該表的IX鎖。

意向鎖是InnoDB自動加的,不須要用戶干預。

對於insert、update、delete,InnoDB會自動給涉及的數據加排他鎖(X);對於通常的Select語句,InnoDB不會加任何鎖,事務能夠經過如下語句給顯示加共享鎖或排他鎖。

共享鎖:SELECT ... LOCK IN SHARE MODE;

排他鎖:SELECT ... FOR UPDATE;

參考資料:

MySQL表級鎖與行級鎖

MySQL鎖的用法之行級鎖

Mysql中那些鎖機制之InnoDB

相關文章
相關標籤/搜索