zoukankan      html  css  js  c++  java
  • 数据库死锁查询处理


    CREATE PROC [dbo].[p_lockinfo]
    @kill_lock_spid BIT = 0 , --是否杀掉死锁的进程,1 杀掉, 0 仅显示
    @show_spid_if_nolock BIT = 1 --如果没有死锁的进程,是否显示正常进程信息,1 显示,0 不显示
    AS
    DECLARE @count INT ,
    @s NVARCHAR(MAX) ,
    @i INT
    SELECT id = IDENTITY( INT,1,1 ),
    标志 ,
    进程ID = spid ,
    线程ID = kpid ,
    块进程ID = blocked ,
    数据库ID = dbid ,
    数据库名 = DB_NAME(dbid) ,
    用户ID = uid ,
    用户名 = loginame ,
    累计CPU时间 = cpu ,
    登陆时间 = login_time ,
    打开事务数 = open_tran ,
    进程状态 = status ,
    工作站名 = hostname ,
    应用程序名 = program_name ,
    工作站进程ID = hostprocess ,
    域名 = nt_domain ,
    网卡地址 = net_address
    INTO #t
    FROM ( SELECT 标志 = '死锁的进程' ,
    spid ,
    kpid ,
    a.blocked ,
    dbid ,
    uid ,
    loginame ,
    cpu ,
    login_time ,
    open_tran ,
    status ,
    hostname ,
    program_name ,
    hostprocess ,
    nt_domain ,
    net_address ,
    s1 = a.spid ,
    s2 = 0
    FROM master..sysprocesses a
    JOIN ( SELECT blocked
    FROM master..sysprocesses
    GROUP BY blocked
    ) b ON a.spid = b.blocked
    WHERE a.blocked = 0
    UNION ALL
    SELECT '|_牺牲品_>' ,
    spid ,
    kpid ,
    blocked ,
    dbid ,
    uid ,
    loginame ,
    cpu ,
    login_time ,
    open_tran ,
    status ,
    hostname ,
    program_name ,
    hostprocess ,
    nt_domain ,
    net_address ,
    s1 = blocked ,
    s2 = 1
    FROM master..sysprocesses a
    WHERE blocked <> 0
    ) a
    ORDER BY s1 ,
    s2
    SELECT @count = @@rowcount ,
    @i = 1
    IF @count = 0
    AND @show_spid_if_nolock = 1
    BEGIN
    INSERT #t
    SELECT 标志 = '正常的进程' ,
    spid ,
    kpid ,
    blocked ,
    dbid ,
    DB_NAME(dbid) ,
    uid ,
    loginame ,
    cpu ,
    login_time ,
    open_tran ,
    status ,
    hostname ,
    program_name ,
    hostprocess ,
    nt_domain ,
    net_address
    FROM master..sysprocesses
    SET @count = @@rowcount
    END
    IF @count > 0
    BEGIN
    CREATE TABLE #t1
    (
    id INT IDENTITY(1, 1) ,
    a NVARCHAR(MAX) ,
    b INT ,
    EventInfo NVARCHAR(MAX)
    )
    IF @kill_lock_spid = 1
    BEGIN
    DECLARE @spid VARCHAR(MAX) ,
    @标志 VARCHAR(MAX)
    WHILE @i <= @count
    BEGIN
    SELECT @spid = 进程ID ,
    @标志 = 标志
    FROM #t
    WHERE id = @i
    INSERT #t1
    EXEC ( 'dbcc inputbuffer(' + @spid + ')'
    )
    IF @标志 = '死锁的进程'
    EXEC('kill '+@spid)
    SET @i = @i + 1
    END
    END
    ELSE
    WHILE @i <= @count
    BEGIN
    SELECT @s = 'dbcc inputbuffer('
    + CAST(进程ID AS VARCHAR) + ')'
    FROM #t
    WHERE id = @i
    INSERT #t1
    EXEC ( @s
    )
    SET @i = @i + 1
    END
    SELECT a.* ,
    进程的SQL语句 = b.EventInfo
    FROM #t a
    JOIN #t1 b ON a.id = b.id
    END

  • 相关阅读:
    adb常用命令和工具
    playwright学习记录
    vue,element-ui表格,多个单元格值可修改(点击聚焦后变成input,失去焦点请求保存)
    vue,element-ui表格,合并单元格,如果需要合并的数据隔行,需要重新排列数组
    cas-5.3.x接入REST登录认证,移动端登录解决方案
    企业级cas5.3登录页面修改
    cas实现单点登录mysql,oracle双版本
    Mycat实现MySQL主从复制和读写分离(双主双从)
    IDEA安装插件后默认存放的位置
    值得推荐的Idea十几大优秀插件
  • 原文地址:https://www.cnblogs.com/zengtianli/p/8625289.html
Copyright © 2011-2022 走看看