首頁 > 資料庫 > mysql教程 > 键范围锁定(Key-Rang Lock)是不是只在序列化级别中出现

键范围锁定(Key-Rang Lock)是不是只在序列化级别中出现

WBOY
發布: 2016-06-07 17:42:05
原創
1019 人瀏覽過

以前一直认为键范围锁定只是在序列化隔离级别中才会出现,但是从论坛的一篇帖子中看到Read-Committed隔离级别中竟然也出现了:59:50.spid24sprocessid=process64

11

 1 

隔离级别下,X locks一直持续到交易结束,香港服务器租用,香港服务器,但是不能避免在删除的同时其他人插入数据。所以需要SERIALIAZABLE隔离级别。

所以,对于类似的操作,不需要用户显示的使用serialization 隔离级别,服务器空间,SQL Server会自动将隔离级别升级从而阻塞其他操作插入数据从而影响外键约束。在这种情况下,SQL Server会使用键范围锁定.这种方法可以避免数据损坏。

SERIALIZABLE级别的锁会一直保持到交易结束,如果一个批次中有多条语句,可能需要一段时间释放这些锁。因为SQL Server知道使用了什么锁,并且什么时候释放才是安全的。

 

另外索引视图维护也是相同的情况。

更多资料可以参考:Read Committed isolation level, indexed views and locking behavior

Conor vs. Isolation Level Upgrade on UPDATE/DELETE Cascading RI

 

本文出自 “关注SQL Server技术” 博客,请务必保留此出处

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板