在資料庫開發過程中,不得不考慮並發性的問題,因為很有可能當別人正在更新表中記錄時,你又從該表中讀資料,那你讀出來的資料有可能就不是你希望得到的資料。可以說有些資料同時只能有一個事物去更新,否則最終顯示給使用者的資料不是資料庫中現存的資料。鎖表就限制不同的事物在同一時間內不允許同時操作一張表,執行個體很簡單,可以用select來鎖定整張表,那別人就不可能更新或是讀取表的記錄。
select * from dbo.Employee with(holdlock); with關鍵字來設定鎖表的方式。下面是with括弧內關鍵字的書名:
NOLOCK(不加鎖)
此選項被選中時,SQL Server 在讀取或修改資料時不加任何鎖。 在這種情況下,使用者有可能讀取到未完成事務(Uncommited Transaction)或復原(Roll Back)中的資料, 即所謂的“髒資料”。
HOLDLOCK(保持鎖)
此選項被選中時,SQL Server 會將此共用鎖定保持至整個事務結束,而不會在途中釋放。
UPDLOCK(修改鎖)
此選項被選中時,SQL Server 在讀取資料時使用修改鎖來代替共用鎖定,並將此鎖保持至整個事務或命令結束。使用此選項能夠保證多個進程能同時讀取資料但只有該進程能修改資料。
TABLOCK(表鎖)
此選項被選中時,SQL Server 將在整個表上置共用鎖定直至該命令結束。 這個選項保證其他進程只能讀取而不能修改資料。
PAGLOCK(頁鎖)
此選項為預設選項, 當被選中時,SQL Server 使用共用頁鎖。
TABLOCKX(排它表鎖)
此選項被選中時,SQL Server 將在整個表上置排它鎖直至該命令或事務結束。這將防止其他進程讀取或修改表中的資料。
HOLDLOCK 持有共用鎖定,直到整個事務完成,應該在被鎖對象不需要時立即釋放,等於SERIALIZABLE交易隔離等級
NOLOCK 語句執行時不發出共用鎖定,允許髒讀 ,等於 READ UNCOMMITTED交易隔離等級
PAGLOCK 在使用一個表鎖的地方用多個頁鎖
READPAST 讓sql server跳過任何鎖定行,執行事務,適用於READ UNCOMMITTED交易隔離等級只跳過RID鎖,不跳過頁,地區和表鎖
ROWLOCK 強制使用行鎖
TABLOCKX 強制使用獨佔表級鎖,這個鎖在事務期間阻止任何其他事務使用這個表
UPLOCK 強制在讀表時使用更新而不用共用鎖定 。
呵呵,上面的夠研究一會的了,我常用的就是holdlock和tablockx,holdlock是鎖定一張表,但是別的事物還是可以讀取的,但不能更新和插入。對於tabllockx,在事物未提交前,連讀取都是阻塞的,直到另一事物提交後才可以讀取,這樣就保證了資料的一致性。不過鎖表需要包含在事物內,否則鎖表是不起作用的。