SqlServer教程

Sql Server 表被锁?查看 高CPU sql ?

本文主要是介绍Sql Server 表被锁?查看 高CPU sql ?,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

 

Sql Server 表被锁?查看 高CPU sql ?

-- 1. 查看 被锁的表,和锁表进程id

select request_session_id 锁表进程, OBJECT_NAME(resource_associated_entity_id) 被锁表名  
from sys.dm_tran_locks where resource_type = 'OBJECT'



-- 2. 查看 cpu 占用高 的sql 语句
 SELECT TOP 100
   total_worker_time/execution_count AS avg_cpu_cost, plan_handle,
   execution_count,
   (SELECT SUBSTRING(text, statement_start_offset/2 + 1,
      (CASE WHEN statement_end_offset = -1
         THEN LEN(CONVERT(nvarchar(max), text)) * 2
         ELSE statement_end_offset
      END - statement_start_offset)/2)
   FROM sys.dm_exec_sql_text(sql_handle)) AS query_text
FROM sys.dm_exec_query_stats
where last_execution_time > '2022-01-11 02:00:39.397'
ORDER BY [avg_cpu_cost] DESC

-- 3. 解锁(干掉解锁进程)
declare @spid  int
Set @spid  = 66 -- 锁表进程
declare @sql varchar(1000)
set @sql = 'kill ' + cast(@spid as varchar)
exec(@sql)

  

这篇关于Sql Server 表被锁?查看 高CPU sql ?的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!