最近一个项目CPU占用非常高,在IIS内设置CPU限制后系统频繁掉线,通过任务管理器发现SQLSever数据库占用CPU达到40%--70%,对于数据库本人也就处在增删查改几个操作水平层面,这次出了问题就硬着头皮上了,好在经过各种百度问题最终解决了,记性不好用的也不多,为防止忘掉就把主要排查方法记录下来。
SELECT TOP 10 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 ORDER BY [avg_cpu_cost] DESC
直接复制粘贴上面的语句就可以查出最耗时的前10条语句。
切换到文本模式
使用下面的语句查看单条语句的执行时间
go set statistics profile on set statistics io on set statistics time on go /** 欲查询CPU执行时间的目标语句**/ go set statistics profile off set statistics io off set statistics time off go
1.单表数据太多:分表、清理过时数据
排查中有两张相同的表,一张表数据量在7000条,另一张表由于问题插入大量无用数据达到三十万+,相同的语句针对两张表的查询时间分别为0ms/900ms,差距非常大。
表1执行时间 表2执行时间
2.数据表没有索引:建立聚集索引
对表结构进行分析,发现没有建立聚集索引,于是针对表及主要操作字段建立聚集索引,建立聚集索引后语句执行时间
3.对语句进行优化:这个只能特定语句特定分析,不断查询语句执行时间来查看优化结果
语句优化完成效果如图
上面2、3都是单独作用时的效果图,可以看到效果还是很明显的,只是并未达到令人满意的效果,但2、3结合使用后效果就惊人了
原文:http://www.cnblogs.com/zhiguzhidao/p/7476401.html