1. 程式人生 > >SQL Server 資料庫 分析 優化 常用語句

SQL Server 資料庫 分析 優化 常用語句

--Begin Cpu 分析優化的相關 Sql --使用DMV來分析SQL Server啟動以來累計使用CPU資源最多的語句。例如下面的語句就可以列出前50名。select 
c.last_execution_time,c.execution_count,c.total_logical_reads,c.total_logical_writes,c.total_elapsed_time,c.last_elapsed_time,
q.
[text]from
(
selecttop50 qs.*from sys.dm_exec_query_stats qs
orderby qs.total_worker_time
desc) as c
cross apply sys.dm_exec_sql_text(plan_handle) as q
orderby c.total_worker_time descgo-- 返回最經常執行的100條語句SELECTTOP100 cp.cacheobjtype,cp.usecounts,cp.size_in_bytes,qs.statement_start_offset,qs.statement_end_offset,qt.dbid ,qt.objectid
,
SUBSTRING(qt.text,qs.statement_start_offset
/2,
(
casewhen qs.statement_end_offset =-1thenlen(convert(nvarchar(max), qt.text)) *2else qs.statement_end_offset end-qs.statement_start_offset)/2) as statement
FROM sys.dm_exec_query_stats qs
cross apply sys.dm_exec_sql_text(qs.sql_handle) as qt
innerjoin sys.dm_exec_cached_plans
as cp on qs.plan_handle=cp.plan_handle
where cp.plan_handle=qs.plan_handle
and cp.usecounts>4ORDERBY[dbid],[Usecounts]DESC-- 返回做IO數目最多的50條語句以及它們的執行計劃selecttop50
(total_logical_reads
/execution_count) as avg_logical_reads,
(total_logical_writes
/execution_count) as avg_logical_writes,
(total_physical_reads
/execution_count) as avg_phys_reads,
Execution_count,
statement_start_offset
as stmt_start_offset, statement_end_offset as stmt_end_offset,
substring(sql_text.text, (statement_start_offset/2),
casewhen (statement_end_offset -statement_start_offset)/2<=0then64000else (statement_end_offset -statement_start_offset)/2end) as exec_statement, sql_text.text,plan_text.*from sys.dm_exec_query_stats
cross apply sys.dm_exec_sql_text(sql_handle) as sql_text
cross apply sys.dm_exec_query_plan(plan_handle) as plan_text
orderby
(total_logical_reads
+ total_logical_writes) /Execution_count Desc-- 計算signal wait佔整wait時間的百分比
--
指令等待 CPU 資源的時間佔總時間的百分比。如果超過 25% ,說明 CPU 緊張selectconvert(numeric(5,4),sum(signal_wait_time_ms)/sum(wait_time_ms))
from Sys.dm_os_wait_stats

-- 計算'Cxpacket'佔整wait時間的百分比
--
Cxpacket:Sql Server 在處理一句代價很大的語句,要不就是沒有合適的索引或篩選條件沒能篩選足夠的記錄,使得語句要返回大量的結果,當 >5% 說明有問題declare@Cxpacketbigintdeclare@Sumwaitsbigintselect@Cxpacket= wait_time_ms
from Sys.dm_os_wait_stats
where wait_type ='Cxpacket'select@Sumwaits=sum(wait_time_ms)
from Sys.dm_os_wait_stats
selectconvert(numeric(5,4),@Cxpacket/@Sumwaits)


-- 查詢當前資料庫上所有使用者表格在Row lock上發生阻塞的頻率declare@dbidintselect@dbid=db_id()
Select dbid=database_id, objectname=object_name(s.object_id)
, indexname
=i.name, i.index_id --, partition_number, row_lock_count, row_lock_wait_count
,
[block %]=cast (100.0* row_lock_wait_count / (1+ row_lock_count) as numeric(15,2))
, row_lock_wait_in_ms
,
[avg row lock waits in ms]=cast (1.0* row_lock_wait_in_ms / (1+ row_lock_wait_count) as numeric(15,2))
from sys.dm_db_index_operational_stats (@dbid, NULL, NULL, NULL) s, sys.indexes i
whereobjectproperty(s.object_id,'IsUserTable') =1and i.object_id= s.object_idand i.index_id = s.index_id
orderby row_lock_wait_count desc--End Cpu 分析優化的相關 Sql