首页 > 代码库 > SQL Server 锁实验(UPDATE加锁探究)

SQL Server 锁实验(UPDATE加锁探究)

本例中使用begin tranwith (holdlock)提示来观察SQL Server在select语句中的锁。
开启事务是为了保证时间极短的查询也能观察到锁情况,因为holdlock会在事务结束后释放锁。
update语句:
技术分享
技术分享
其上锁情况为:
技术分享
技术分享
可以看到加锁情况如下:
1.添加了表级IX锁
2.针对数据页3105添加了IX锁,以便更新其中数据行
3.对数据页3105中对应的数据行添加了X模式的KEY锁
4.更新完数据后要更新包含ClinicID列的相关索引,我们先看一下涉及到这个列的索引有哪些:(可以看到确实是60号索引)
select * from sys.indexes where object_id=OBJECT_ID(‘RIS_REQUEST‘)
技术分享
技术分享
对索引页50160、1458239添加了IX锁,以便更新其中索引行
5.对以上2个索引页内的索引行添加X模式KEY锁,更新索引行完成。
这里有个疑问:我是按主键进行更新的,这意味着只涉及到一个数据行,索引也应该只有一行对应才对,为何会导致2个索引记录的X模式KEY锁出现?
只能去看50160、1458239这两个页的具体内容了,这里我把两个页的具体内容全部用dbcc page转储出来:
50160页只截取了可能包含主键2012121218060024的部分:
技术分享
技术分享
1458239页总共只有这么多行的记录:
技术分享
技术分享
可以看到主键值2012121218060024的索引就是在1458239索引页的第2行,其对应的hash值也是sp_lock中看到的7be5a319785d,而另一个hash值fcee1248c8e6对应的索引行则没有找到,这可以预见,因为ClinicID被更新后其HASH值必定发生变化。
     

SQL Server 锁实验(UPDATE加锁探究)