原文地址:
http://technet.microsoft.com/zh-cn/library/bb838723.aspxsql
Microsoft SQL Server 2005 提供了一些工具來監控數據庫。方法之一是動態管理視圖。動態管理視圖 (DMV) 和動態管理函數 (DMF) 返回的服務器狀態信息可用於監控服務器實例的運行情況、診斷問題和優化性能。數據庫
常規服務器動態管理對象包括:服務器
此部分介紹爲監控 SQL Server 運行情況而針對這些動態管理視圖和函數運行的一些經常使用查詢。優化
摘錄部分精彩SQL以下:
this
下面的查詢顯示 CPU 平均佔用率最高的前 50 個 SQL 語句。
SELECT
TOP
50
total_worker_time
/
execution_count
AS
[
Avg CPU Time
]
,
(
SELECT
SUBSTRING
(
text
,statement_start_offset
/
2
,(
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 Time
]
DESC
下面的查詢顯示一些可能佔用大量 CPU 使用率的運算符(例如 ‘%Hash Match%’、‘%Sort%’)以找出可疑對象。
select
*
from
sys.dm_exec_cached_plans
cross
apply sys.dm_exec_query_plan(plan_handle)
where
cast
(query_plan
as
nvarchar
(
max
))
like
'
%Sort%
'
or
cast
(query_plan
as
nvarchar
(
max
))
like
'
%Hash Match%
'
運行下面的 DMV 查詢以查看 CPU、計劃程序內存和緩衝池信息。
select
cpu_count,
hyperthread_ratio,
scheduler_count,
physical_memory_in_bytes
/
1024
/
1024
as
physical_memory_mb,
virtual_memory_in_bytes
/
1024
/
1024
as
virtual_memory_mb,
bpool_committed
*
8
/
1024
as
bpool_committed_mb,
bpool_commit_target
*
8
/
1024
as
bpool_target_mb,
bpool_visible
*
8
/
1024
as
bpool_visible_mb
from
sys.dm_os_sys_info
下面的示例查詢顯示已從新編譯的前 25 個存儲過程。plan_generation_num 指示該查詢已從新編譯的次數。
select
top
25
sql_text.
text
,
sql_handle,
plan_generation_num,
execution_count,
dbid,
objectid
from
sys.dm_exec_query_stats a
cross
apply sys.dm_exec_sql_text(sql_handle)
as
sql_text
where
plan_generation_num
>
1
order
by
plan_generation_num
desc
下面的 DMV 查詢可用於查找哪些批處理/請求生成的 I/O 最多。以下所示的 DMV 查詢可用於查找可生成最多 I/O 的前五個請求。調整這些查詢將提升系統性能。
select
top
5
(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,
sql_handle,
plan_handle
from
sys.dm_exec_query_stats
order
by
(total_logical_reads
+
total_logical_writes)
Desc