国产一级a片免费看高清,亚洲熟女中文字幕在线视频,黄三级高清在线播放,免费黄色视频在线看

打開APP
userphoto
未登錄

開通VIP,暢享免費電子書等14項超值服

開通VIP
Sql Server鎖表
Sql Server鎖表

在數(shù)據(jù)庫開發(fā)過程中,不得不考慮并發(fā)性的問題,因為很有可能當(dāng)別人正在更新表中記錄時,你又從該表中讀數(shù)據(jù),那你讀出來的數(shù)據(jù)有可能就不是你希望得到的數(shù)據(jù)??梢哉f有些數(shù)據(jù)同時只能有一個事物去更新,否則最終顯示給用戶的數(shù)據(jù)不是數(shù)據(jù)庫中現(xiàn)存的數(shù)據(jù)。鎖表就限制不同的事物在同一時間內(nèi)不允許同時操作一張表,實例很簡單,可以用select來鎖定整張表,那別人就不可能更新或是讀取表的記錄。

select * from dbo.Employee with(holdlock); with關(guān)鍵字來設(shè)置鎖表的方式。下面是with括號內(nèi)關(guān)鍵字的書名: 

NOLOCK(不加鎖)

此選項被選中時,SQL Server 在讀取或修改數(shù)據(jù)時不加任何鎖。 在這種情況下,用戶有可能讀取到未完成事務(wù)(Uncommited Transaction)或回滾(Roll Back)中的數(shù)據(jù), 即所謂的臟數(shù)據(jù)

HOLDLOCK(保持鎖)

此選項被選中時,SQL Server 會將此共享鎖保持至整個事務(wù)結(jié)束,而不會在途中釋放。

UPDLOCK(修改鎖)

此選項被選中時,SQL Server 在讀取數(shù)據(jù)時使用修改鎖來代替共享鎖,并將此鎖保持至整個事務(wù)或命令結(jié)束。使用此選項能夠保證多個進程能同時讀取數(shù)據(jù)但只有該進程能修改數(shù)據(jù)。

TABLOCK(表鎖)

此選項被選中時,SQL Server 將在整個表上置共享鎖直至該命令結(jié)束。 這個選項保證其他進程只能讀取而不能修改數(shù)據(jù)。

PAGLOCK(頁鎖)

此選項為默認選項, 當(dāng)被選中時,SQL Server 使用共享頁鎖。

TABLOCKX(排它表鎖)

此選項被選中時,SQL Server 將在整個表上置排它鎖直至該命令或事務(wù)結(jié)束。這將防止其他進程讀取或修改表中的數(shù)據(jù)。

HOLDLOCK 持有共享鎖,直到整個事務(wù)完成,應(yīng)該在被鎖對象不需要時立即釋放,等于SERIALIZABLE事務(wù)隔離級別

NOLOCK 語句執(zhí)行時不發(fā)出共享鎖,允許臟讀 ,等于 READ UNCOMMITTED事務(wù)隔離級別

PAGLOCK 在使用一個表鎖的地方用多個頁鎖

READPAST sql server跳過任何鎖定行,執(zhí)行事務(wù),適用于READ UNCOMMITTED事務(wù)隔離級別只跳過RID鎖,不跳過頁,區(qū)域和表鎖

ROWLOCK 強制使用行鎖

TABLOCKX 強制使用獨占表級鎖,這個鎖在事務(wù)期間阻止任何其他事務(wù)使用這個表

UPLOCK 強制在讀表時使用更新而不用共享鎖 。

呵呵,上面的夠研究一會的了,我常用的就是holdlocktablockx,holdlock是鎖定一張表,但是別的事物還是可以讀取的,但不能更新和插入。對于tabllockx,在事物未提交前,連讀取都是阻塞的,直到另一事物提交后才可以讀取,這樣就保證了數(shù)據(jù)的一致性。不過鎖表需要包含在事物內(nèi),否則鎖表是不起作用的。
本站僅提供存儲服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊舉報。
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
SQL Server 2008鎖定表的SQL語句介紹與應(yīng)用
Sql 鎖的理解
SQL鎖機制高級篇-------一
Sql Server 鎖機制
SQL Server查詢使用鍵查找時鎖申請及釋放順序
SQL優(yōu)化中的重要概念:鎖定
更多類似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長圖 關(guān)注 下載文章
綁定賬號成功
后續(xù)可登錄賬號暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點擊這里聯(lián)系客服!

聯(lián)系客服