zoukankan      html  css  js  c++  java
  • 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已结被授予锁,但又再次申请锁,最终导致死锁。

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

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

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

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

  • 相关阅读:
    .Net在arraylist用法
    ORM查询方法
    正则表达式大全
    checkbox修改功能保存功能绑定
    Web ASP.Net运行机制
    面试题
    Sql Server 中锁的概念
    由nginx和spring boot中tomcat配置不当引起的问题
    记录一次由事务可重复读引起的问题
    Ubuntu18.04没有声音的解决
  • 原文地址:https://www.cnblogs.com/TeyGao/p/5644844.html
Copyright © 2011-2022 走看看