SQL Server 简单插入语句超时

标签 sql sql-server database nhibernate timeout

我有一个包含 6 列的简单表格。大多数时候,对它的任何插入语句都可以正常工作,但偶尔我会遇到 DB Timeout 异常: 超时已过。在操作完成之前超时期限已过,或者服务器没有响应。声明已终止。

超时设置为 10 秒。

我应该提到我正在使用 NHibernate,并且该语句还在插入本身之后包含一个“select SCOPE_IDENTITY()”。

我的想法是该表被锁定或其他原因,但当时该表上没有其他语句在运行。

所有的插入都非常简单,在 sql profiler 中一切看起来都很正常,表没有索引,只有 PK(页面填充度:98.57 %)。

关于我应该寻找什么的任何想法?

谢谢。

最佳答案

我认为您最有可能的罪魁祸首是来自另一个事务的阻塞锁(或者可能来自触发器或幕后的其他东西)。

最简单的判断方法是启动 INSERT,当它挂起时,在同一服务器的另一个窗口中运行 EXEC SP_WHO2。这将列出所有当前的数据库事件,并有一个名为 BLK 的列,它将显示当前是否有任何进程被阻止。检查挂起连接的 SPID 以查看它是否在 BLK 列中有任何内容,如果有,那就是阻止您的进程。

即使您认为没有任何其他语句在运行,唯一可以确定的方法是使用像这样的 SP 列出当前事务。

关于SQL Server 简单插入语句超时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/447201/

相关文章:

mysql - 如何向 SQL 查询中的列添加值?

sql - Oracle SQL - 在不知道列名的情况下选择列

mysql - 今天开始的时间值

sql-server - EF6 将每个存储过程调用包装在其自己的事务中。如何防止这种情况发生?

c# - 在方法中将数据集作为对象返回

php - SQLSTATE[23000] : Integrity constraint violation: 1452 Cannot add or update a child row:a foreign key

sql-server - TRY_PARSE 使函数非确定性

mysql - asp.net 数据库仅返回一个值而不是整个集合

mysql - Doctrine 查询结果

mysql - 工作台出现 LEFT JOIN 错误