T-SQL:手动锁定表几分钟

本文关键字:分钟 几分钟 锁定 T-SQL | 更新日期: 2023-09-27 18:17:46

我知道这将是奇怪的,但我想在我的MVC应用程序中触发一个错误,这个错误将基于LINQ查询,我想从表中获得一条记录。虽然这条记录将被阻塞(数据库/表/行)级别使用T-SQL命令(例如,无限循环总是更新这条记录),然后我的LINQ查询将执行查询来读取该记录。当LINQ尝试时,结果应该是20-30秒后暂停,有人以前试过吗?

T-SQL:手动锁定表几分钟

如果我正确理解了您的问题,听起来您想要强制表锁以进行测试。要在SQL Server中做到这一点,您可以创建并运行一个存储过程,该存储过程将在感兴趣的表上产生排他表锁。当该锁处于活动状态时,您可以运行要测试的程序。

下面的存储过程应该锁定表2分钟。您可以根据需要更改延迟参数。

BEGIN TRAN  
SELECT TOP (1) 1 FROM TABLE WITH (TABLOCKX)
WAITFOR DELAY '00:02:00' 
ROLLBACK TRAN   
GO 

下面的stackoverflow帖子中描述了这样做的一般方法。MSDN链接提供了关于WAITFOR语句的一些附加信息。

原来的stackoverflow post

补充MSDN post