表锁tablock是会给表所有数据附加共享锁,但是只是当前语句有效,语句执行完毕,锁释放,而不会持续到事务结束,而tablockX表锁是持续到事务结束的锁

 

holdlock锁,锁定的范围会根据where条件后是否是聚集索引来改变的

例如

begin tran 
select * from t1 with(holdlock)
where id= 29
waitfor delay '00:00:05' 
commit 

where条件的id是聚集索引,所以该语句只会给id为29的数据附加共享锁,其他数据则不会,其他事务可以对id不等于29的其他数据进行update和delete操作

如果换成

begin tran 
select * from t1 with(holdlock)
where colA= '29'
waitfor delay '00:00:05' 
commit 

where条件的colA不是聚集索引,该查询会导致表扫描,所以会给整个表数据附加共享锁,并且持续到事务结束,其他事务只能读该表数据而不能进行其他操作

 

以上结论在sqlserver2008测试的

 

相关文章:

  • 2022-12-23
  • 2021-09-27
  • 2021-12-23
  • 2021-11-30
  • 2022-02-04
  • 2021-12-25
  • 2022-12-23
  • 2021-09-28
猜你喜欢
  • 2021-04-14
  • 2022-12-23
  • 2021-11-30
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
相关资源
相似解决方案