SQL SERVER 查询死锁

方法一:

WITH    CTE_SID ( BSID, SID, sql_handle )

          AS ( SELECT   blocking_session_id ,

                        session_id ,

                        sql_handle

               FROM     sys.dm_exec_requests

               WHERE    blocking_session_id <> 0

               UNION ALL

               SELECT   A.blocking_session_id ,

                        A.session_id ,

                        A.sql_handle

               FROM     sys.dm_exec_requests A

                        JOIN CTE_SID B ON A.session_id = B.BSID

             )

    SELECT  C.BSID ,

            C.SID ,

            S.login_name ,

            S.host_name ,

            S.status ,

            S.cpu_time ,

            S.memory_usage ,

            S.last_request_start_time ,

            S.last_request_end_time ,

            S.logical_reads ,

            S.row_count ,

            Q.text

    FROM    CTE_SID C

            JOIN sys.dm_exec_sessions S ON C.SID = S.session_id

            CROSS APPLY sys.dm_exec_sql_text(C.sql_handle) Q

    ORDER BY SID;

 

方法二:

USE master;

GO

 

DECLARE @spid INT ,

    @bl INT;

DECLARE s_cur CURSOR

FOR

    SELECT  0 ,

            blocked

    FROM    ( SELECT    *

              FROM      sysprocesses

              WHERE     blocked > 0

            ) a

    WHERE   NOT EXISTS ( SELECT *

                         FROM   ( SELECT    *

                                  FROM      sysprocesses

                                  WHERE     blocked > 0

                                ) b

                         WHERE  a.blocked = spid )

    UNION

    SELECT  spid ,

            blocked

    FROM    sysprocesses

    WHERE   blocked > 0;

OPEN s_cur;

FETCH NEXT FROM s_cur INTO @spid, @bl;

WHILE @@FETCH_STATUS = 0

    BEGIN

        IF @spid = 0

            SELECT  '引起数据库死锁的是: ' + CAST(@bl AS VARCHAR(10))

                    + '进程号,其执行的SQL语法如下';

        ELSE

            SELECT  '进程号SPID:' + CAST(@spid AS VARCHAR(10)) + '被' + '进程号SPID:'

                    + CAST(@bl AS VARCHAR(10)) + '阻塞,其当前进程执行的SQL语法如下';

        DBCC INPUTBUFFER (@bl );

        FETCH NEXT FROM s_cur INTO @spid, @bl;

    END;

CLOSE s_cur;

DEALLOCATE s_cur;

转载于:https://www.cnblogs.com/pgboy/p/5496563.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值