T-SQL:手动锁定表几分钟[重复]

Posted

技术标签:

【中文标题】T-SQL:手动锁定表几分钟[重复]【英文标题】:T-SQL: Lock a table manually for some minutes [duplicate] 【发布时间】:2014-08-12 20:05:42 【问题描述】:

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

【问题讨论】:

【参考方案1】:

如果我正确理解您的问题,听起来您想强制锁定表以进行测试。要使用 SQL Server 执行此操作,您可以创建并运行一个存储过程,该过程将导致感兴趣的表上的排他表锁定。当该锁处于活动状态时,您可以运行要测试的程序。

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

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

下面的 *** 帖子中描述了执行此操作的一般方法。 MSDN 链接提供了有关 WAITFOR 语句的一些附加信息。

Original *** post

Supplementary MSDN post

希望对你有帮助。

【讨论】:

以上是关于T-SQL:手动锁定表几分钟[重复]的主要内容,如果未能解决你的问题,请参考以下文章

T-SQL:删除所有重复的行但保留一个[重复]

T-SQL Recipes之删除重复行

T-SQL,LINQ取集合当中的重复项

标记重复记录的T-SQL查询

如果存在,则 T-SQL 删除类型 [重复]

重新启动 T-SQL 中的行号 [重复]