SQL SERVER--单回话下的死锁

Posted 笑东风

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL SERVER--单回话下的死锁相关的知识,希望对你有一定的参考价值。

很多时候,死锁由两个或多个会话请求其他Session持有的锁而同时又持有其他Session,但也有一些特殊的死锁仅由单个Session锁触发,今天看到一篇相关的文章,搬运过来与各位共享!

引发死锁的代码:

执行环境SQL SERVER 2012 (11.0.5058)

BEGIN TRANSACTION;
GO
SELECT \'CREATE TYPE EmailAddress\'
GO
CREATE TYPE EmailAddress FROM VARCHAR(320);
GO
SELECT \'CREATE dbo.foo\'
GO
CREATE PROCEDURE dbo.foo 
(
    @param EmailAddress
)
AS
BEGIN 

    SET NOCOUNT ON;
    DECLARE @x TABLE ( e EmailAddress );

    INSERT  @x
    SELECT  @param;

END;
GO
SELECT \'EXEC dbo.foo\'
GO
DECLARE @x EmailAddress;
SET @x = N\'whatever\';
EXEC dbo.foo @param = N\'whatever\';

SELECT \'\'
GO
SELECT \'ROLLBACK TRANSACTION\'
ROLLBACK TRANSACTION;


执行上面的代码后,通过Profile可以捕获到如下死锁视图:

使用sp_lock查看锁会发现:

在元数据锁7(101:0:0)上回话61已结被授予锁,但又再次申请锁,最终导致死锁。

===================================================

该场景在实际业务中几乎不会发生,一般没谁会把存储过程和用户自定义类型的创建放到事务中吧,尤其是将存储过程创建和调用放到同一个事务中。避免该问题的办法就是将存储过程和用户自定义类型的创建放到单独的事务中提交。

===================================================

姿势涨完了,该妹子镇贴!

 

以上是关于SQL SERVER--单回话下的死锁的主要内容,如果未能解决你的问题,请参考以下文章

SQL SERVER

试图防止这种死锁发生在我在 SQL Server 上的 .NET 代码中

如何在单个进程中模拟 SQL Server 中的死锁?

在Tomcat的安装目录下conf目录下的server.xml文件中增加一个xml代码片段,该代码片段中每个属性的含义与用途

一个SQL Server 2008 R2 死锁的问题解决

Microsoft SQL Server 代码片段收集