sql-server – 密钥锁实际锁定什么资源?

前端之家收集整理的这篇文章主要介绍了sql-server – 密钥锁实际锁定什么资源?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我知道钥匙锁在索引中锁定一个键.但是,“关键”究竟是什么意思呢?

例如,如果我在一个姓氏列上有一个非聚集索引,并尝试更新surname =“Jones”,那么我会有效地锁定姓氏是“Jones”的表中的每一行吗?或者将索引锁定在更高级别,阻止访问除“琼斯”以外的姓氏的行?

我问的原因是在线书籍关于锁定粒度和层次结构的这个注释:

KEY: A row lock within an index used to protect key ranges in serializable transactions.

这表明一系列的钥匙将被锁定,而不仅仅是一个.

解决方法

键锁影响与给定谓词(种类)匹配的所有行 – 在示例中,所有具有surname =’Jones’的行都将受到影响.

使用单词“range”,因为根据谓词可能会影响行范围,例如,如果谓词为age> 18那么年龄大于18的所有行都会受到影响.

同样重要的是要明白,键锁并不是简单地单独锁定索引中的每个匹配行 – 您的示例键锁不仅会影响索引中所有现有行的姓氏“Jones”,还会影响任何修改现有行的尝试或者插入一个名为“琼斯”的新行.

它可能有助于以稍微不同的方式思考锁 – 只有当sql Server尝试获得可能不兼容的另一个锁(即同时具有两个锁是不合法的)时,锁才有效果.例如,如果您在具有年龄>的行上拥有专属密钥锁定18,并尝试插入或修改age = 42的行,然后sql Server将首先尝试获取相关锁 – 看到存在具有年龄>的行的现有密钥锁. 18 sql Server确定锁是不兼容的,并采取相应的行动.

猜你在找的MsSQL相关文章