Sql Server 中鎖的簡單瞭解

來源:互聯網
上載者:User

標籤:

1 如何鎖一個表的某一行 

SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED SELECT * FROM table ROWLOCK WHERE id = 1 

2 鎖定資料庫的一個表 

SELECT * FROM table WITH (HOLDLOCK) 

加鎖語句: 

sybase: update 表 set col1=col1 where 1=0 ; MSSQL: select col1 from 表 (tablockx) where 1=0 ; oracle: LOCK TABLE 表 IN EXCLUSIVE MODE ; 

加鎖後其它人不可操作,直到加鎖使用者解鎖,用commit或rollback解鎖 。幾個例子協助大家加深印象 

設table1(A,B,C) A B C a1 b1 c1 a2 b2 c2 a3 b3 c3 

1)排它鎖 
建立兩個串連 
在第一個串連中執行以下語句 

begin tran update table1 set A=‘aa‘ where B=‘b2‘ waitfor delay ‘00:00:30‘ --等待30秒 commit tran 

在第二個串連中執行以下語句 

begin tran select * from table1 where B=‘b2‘ commit tran 

若同時執行上述兩個語句,則select查詢必須等待update執行完畢才能執行即要等待30秒 

2)共用鎖定 
在第一個串連中執行以下語句 

begin tran select * from table1 holdlock -holdlock人為加鎖 where B=‘b2‘ waitfor delay ‘00:00:30‘ --等待30秒 commit tran 

在第二個串連中執行以下語句 

begin tran select A,C from table1 where B=‘b2‘ update table1 set A=‘aa‘ where B=‘b2‘ commit tran 

若同時執行上述兩個語句,則第二個串連中的select查詢可以執行 而update必須等待第一個事務釋放共用鎖定轉為排它鎖後才能執行 即要等待30秒 

3)死結 

增設table2(D,E) D E d1 e1 d2 e2 在第一個串連中執行以下語句 begin tran update table1 set A=‘aa‘ where B=‘b2‘ waitfor delay ‘00:00:30‘ update table2 set D=‘d5‘ where E=‘e1‘ commit tran 

在第二個串連中執行以下語句 

begin tran update table2 set D=‘d5‘ where E=‘e1‘ waitfor delay ‘00:00:10‘ update table1 set A=‘aa‘ where B=‘b2‘ commit tran 

同時執行,系統會檢測出死結,並中止進程 。

補充一點: 
Sql Server2000支援的表級鎖定提示 
HOLDLOCK 持有共用鎖定,直到整個事務完成,應該在被鎖對象不需要時立即釋放,等於SERIALIZABLE交易隔離等級 
NOLOCK 語句執行時不發出共用鎖定,允許髒讀 ,等於 READ UNCOMMITTED交易隔離等級 
PAGLOCK 在使用一個表鎖的地方用多個頁鎖 
READPAST 讓sql server跳過任何鎖定行,執行事務,適用於READ UNCOMMITTED交易隔離等級只跳過RID鎖,不跳過頁,地區和表鎖 
ROWLOCK 強制使用行鎖 
TABLOCKX 強制使用獨佔表級鎖,這個鎖在事務期間阻止任何其他事務使用這個表 
UPLOCK 強制在讀表時使用更新而不用共用鎖定 
應用程式鎖: 
應用程式鎖就是產生用戶端程式碼的鎖,而不是sql server本身產生的鎖 
處理應用程式鎖的兩個過程 
sp_getapplock 鎖定應用程式資源 
sp_releaseapplock 為應用程式資源解鎖 
注意: 鎖定資料庫的一個表的區別 
SELECT * FROM table WITH (HOLDLOCK) 其他事務可以讀取表,但不能更新刪除 
SELECT * FROM table WITH (TABLOCKX) 其他事務不能讀取表,更新和刪除

Sql Server 中鎖的簡單瞭解

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.