当然看的过程中,其实自己有个疑问:
安新网站建设公司创新互联,安新网站设计制作,有大型网站制作公司丰富经验。已为安新近1000家提供企业网站建设服务。企业网站搭建\外贸网站建设要多少钱,请找那个售后服务好的安新做网站的公司定做!
对于键查找这类查询,会申请哪些锁,锁申请和释放的顺序是怎样的?
准备
备注:测试表仍然使用高兄文中创建的测试表testklup
在开始之前,使用dbcc ind 命令先看下测试表的数据组织情况
然后语句执行计划图如下:
查看申请了哪些锁
为了得到查询会申请哪些锁,通过如下这条查询就可以得到
- begin tran
- select cont2 from testklup with(HOLDLOCK) where nlskey=1
在默认的事务隔离级别下,开启事务,然后查询中使用HOLDLOCK提示。HOLDLOCK将共享锁保留到事务完成,而不是在相应的表、行或数据页不再需要时就立即释放锁。
然后使用DMV视图sys.dm_tran_locks来查看持有锁的情况,查询结果如下:
从查询结果,可以得出申请了如下的锁:
1)在表object上申请了IS锁
2)在非聚集索引PAGE上申请了IS锁
3)在非聚集索引KEY上申请了S锁
4)在聚集索引的PAGE上申请了IS锁
5)在聚集索引的KEY上申请了S锁
查看锁申请和释放的顺序
我们使用SQL Profiler来跟踪锁申请和释放的事件。模板选择TSQL-LOCKS,只跟踪运行语句的会话spid,同时事件增加Lock:Acquired和Lock:Released。执行查询跟踪结果如下:
从上图可以得出如下信息:
1) 非聚集索引申请的S锁需等到键查找在聚集索引上查找完毕后才释放。这其实也是键查找导致死锁发生的条件
2)锁申请和释放的顺序有点类似于进栈和出栈,先申请的***释放
3)疑问:为什么没有键查找在聚集索引Key上申请的S锁记录呢?锁肯定是有,但不清楚为什么Profiler没有记录到,因为我跟踪查询加HOLD时,是会在***申请一个S锁的,结果如下:
小结
通过本文,我们知道了一个简单的键查找查询会申请哪些锁,同时,锁申请和释放的顺序是怎样的。在非聚集索引上申请的锁一直到键查找执行完毕才会释放。
文章题目:SQLServer查询使用键查找时锁申请及释放顺序
本文网址:http://www.gawzjz.com/qtweb2/news19/22119.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联