技術(shù)員聯(lián)盟提供win764位系統(tǒng)下載,win10,win7,xp,裝機(jī)純凈版,64位旗艦版,綠色軟件,免費(fèi)軟件下載基地!

當(dāng)前位置:主頁(yè) > 教程 > 服務(wù)器類(lèi) >

使用DMV和DMF分析數(shù)據(jù)庫(kù)性能

來(lái)源:技術(shù)員聯(lián)盟┆發(fā)布時(shí)間:2018-09-01 00:04┆點(diǎn)擊:

  服務(wù)器等待的原因

  SELECT TOP 10

  [Wait type] = wait_type,

  [Wait time (s)] = wait_time_ms / 1000,

  [% waiting] = CONVERT(DECIMAL(12,2), wait_time_ms * 100.0

  / SUM(wait_time_ms) OVER())

  FROM sys.dm_os_wait_stats

  WHERE wait_type NOT LIKE '%SLEEP%'

  ORDER BY wait_time_ms DESC;

  讀和寫(xiě)

  SELECT TOP 10

  [Total Reads] = SUM(total_logical_reads)

  ,[Execution count] = SUM(qs.execution_count)

  ,DatabaseName = DB_NAME(qt.dbid)

  FROM sys.dm_exec_query_stats qs

  CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) as qt

  GROUP BY DB_NAME(qt.dbid)

  ORDER BY [Total Reads] DESC;

  SELECT TOP 10

  [Total Writes] = SUM(total_logical_writes)

  ,[Execution count] = SUM(qs.execution_count)

  ,DatabaseName = DB_NAME(qt.dbid)

  FROM sys.dm_exec_query_stats qs

  CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) as qt

  GROUP BY DB_NAME(qt.dbid)

  ORDER BY [Total Writes] DESC;

  數(shù)據(jù)庫(kù)缺失索引

  SELECT

  DatabaseName = DB_NAME(database_id)

  ,[Number Indexes Missing] = count(*)

  FROM sys.dm_db_missing_index_details

  GROUP BY DB_NAME(database_id)

  ORDER BY 2 DESC;

  缺失索引列表信息

  SELECT DatabaseName = DB_NAME(database_id),* FROM sys.dm_db_missing_index_details Order BY DB_NAME(database_id)

  高開(kāi)銷(xiāo)的缺失索引

  SELECT TOP 10

  [Total Cost] = ROUND(avg_total_user_cost * avg_user_impact * (user_seeks + user_scans),0)

  , avg_user_impact

  , TableName = statement

  , [EqualityUsage] = equality_columns

  , [InequalityUsage] = inequality_columns

  , [Include Cloumns] = included_columns

  FROM sys.dm_db_missing_index_groups g

  INNER JOIN sys.dm_db_missing_index_group_stats s

  ON s.group_handle = g.index_group_handle

  INNER JOIN sys.dm_db_missing_index_details d

  ON d.index_handle = g.index_handle

  ORDER BY [Total Cost] DESC;

  確定開(kāi)銷(xiāo)最高的未使用索引

  SELECT TOP 10 [Total Cost]=ROUND(avg_total_user_cost * avg_user_impact * (user_seeks + user_scans),0),avg_user_impact,TableName=statement, [EqualityUsage]=equality_columns,[InequalityUsage]=inequality_columns,[Include Cloumns] = included_columns FROM sys.dm_db_missing_index_groups g INNER JOIN sys.dm_db_missing_index_group_stats s ON s.group_handle = g.index_group_handle INNER JOIN sys.dm_db_missing_index_details d ON d.index_handle = g.index_handle ORDER BY [Total Cost] DESC;

  確定最高開(kāi)銷(xiāo)索引所使用的腳本并顯示結(jié)果。

  -- Create required table structure only.

  -- Note: this SQL must be the same as in the Database loop given in the following step.

  SELECT TOP 1

  [Maintenance cost] = (user_updates + system_updates)

  ,[Retrieval usage] = (user_seeks + user_scans + user_lookups)

  ,DatabaseName = DB_NAME()

  ,TableName = OBJECT_NAME(s.[object_id])

  ,IndexName = i.name

  INTO #TempMaintenanceCost

  FROM sys.dm_db_index_usage_stats s

  INNER JOIN sys.indexes i ON s.[object_id] = i.[object_id]

  AND s.index_id = i.index_id

  WHERE s.database_id = DB_ID()

  AND OBJECTPROPERTY(s.[object_id], 'IsMsShipped') = 0

  AND (user_updates + system_updates) > 0 -- Only report on active rows.

  AND s.[object_id] = -999 -- Dummy value to get table structure.

  ;

  -- Loop around all the databases on the server.

  EXEC sp_MSForEachDB 'USE [?];

  -- Table already exists.

  INSERT INTO #TempMaintenanceCost

  SELECT TOP 10

  [Maintenance cost] = (user_updates + system_updates)

  ,[Retrieval usage] = (user_seeks + user_scans + user_lookups)

  ,DatabaseName = DB_NAME()

  ,TableName = OBJECT_NAME(s.[object_id])

  ,IndexName = i.name

  FROM sys.dm_db_index_usage_stats s

  INNER JOIN sys.indexes i ON s.[object_id] = i.[object_id]

  AND s.index_id = i.index_id

  WHERE s.database_id = DB_ID()

  AND i.name IS NOT NULL -- Ignore HEAP indexes.

  AND OBJECTPROPERTY(s.[object_id], ''IsMsShipped'') = 0

  AND (user_updates + system_updates) > 0 -- Only report on active rows.

  ORDER BY [Maintenance cost] DESC

  ;

  '

  -- Select records.

  SELECT TOP 10 * FROM #TempMaintenanceCost

  ORDER BY [Maintenance cost] DESC

  -- Tidy up.

  DROP TABLE #TempMaintenanceCost

  顯示索引已被使用的次數(shù),并按“使用率”排序。

  -- Create required table structure only.

  -- Note: this SQL must be the same as in the Database loop given in the -- following step.

  SELECT TOP 1

  [Usage] = (user_seeks + user_scans + user_lookups)

  ,DatabaseName = DB_NAME()

  ,TableName = OBJECT_NAME(s.[object_id])

  ,IndexName = i.name

  INTO #TempUsage

  FROM sys.dm_db_index_usage_stats s

  INNER JOIN sys.indexes i ON s.[object_id] = i.[object_id]

  AND s.index_id = i.index_id

  WHERE s.database_id = DB_ID()

  AND OBJECTPROPERTY(s.[object_id], 'IsMsShipped') = 0

  AND (user_seeks + user_scans + user_lookups) > 0

  -- Only report on active rows.

  AND s.[object_id] = -999 -- Dummy value to get table structure.

  ;

  -- Loop around all the databases on the server.

  EXEC sp_MSForEachDB 'USE [?];

  -- Table already exists.

  INSERT INTO #TempUsage

  SELECT TOP 10

  [Usage] = (user_seeks + user_scans + user_lookups)

  ,DatabaseName = DB_NAME()

  ,TableName = OBJECT_NAME(s.[object_id])

  ,IndexName = i.name

  FROM sys.dm_db_index_usage_stats s

  INNER JOIN sys.indexes i ON s.[object_id] = i.[object_id]

  AND s.index_id = i.index_id

  WHERE s.database_id = DB_ID()

  AND i.name IS NOT NULL -- Ignore HEAP indexes.

  AND OBJECTPROPERTY(s.[object_id], ''IsMsShipped'') = 0

  AND (user_seeks + user_scans + user_lookups) > 0 -- Only report on active rows.

  ORDER BY [Usage] DESC

  ;

  '

  -- Select records.

  SELECT TOP 10 * FROM #TempUsage ORDER BY [Usage] DESC

  -- Tidy up.

  DROP TABLE #TempUsage

  邏輯上最零碎的索引所使用的腳本

  -- Create required table structure only.

  -- Note: this SQL must be the same as in the Database loop given in the -- following step.

  SELECT TOP 1

  DatbaseName = DB_NAME()

  ,TableName = OBJECT_NAME(s.[object_id])

  ,IndexName = i.name

  ,[Fragmentation %] = ROUND(avg_fragmentation_in_percent,2)

  INTO #TempFragmentation

  FROM sys.dm_db_index_physical_stats(db_id(),null, null, null, null) s

  INNER JOIN sys.indexes i ON s.[object_id] = i.[object_id]

  AND s.index_id = i.index_id

  WHERE s.[object_id] = -999 -- Dummy value just to get table structure.

  ;

  -- Loop around all the databases on the server.

  EXEC sp_MSForEachDB 'USE [?];

  -- Table already exists.

  INSERT INTO #TempFragmentation

  SELECT TOP 10

  DatbaseName = DB_NAME()

  ,TableName = OBJECT_NAME(s.[object_id])

  ,IndexName = i.name

  ,[Fragmentation %] = ROUND(avg_fragmentation_in_percent,2)

  FROM sys.dm_db_index_physical_stats(db_id(),null, null, null, null) s

  INNER JOIN sys.indexes i ON s.[object_id] = i.[object_id]

  AND s.index_id = i.index_id

  WHERE s.database_id = DB_ID()

  AND i.name IS NOT NULL -- Ignore HEAP indexes.

  AND OBJECTPROPERTY(s.[object_id], ''IsMsShipped'') = 0

  ORDER BY [Fragmentation %] DESC

  ;

  '

  -- Select records.

  SELECT TOP 10 * FROM #TempFragmentation ORDER BY [Fragmentation %] DESC

  -- Tidy up.

  DROP TABLE #TempFragmentation

  獲得IO高的查詢(xún)

  SELECT TOP 10

  [Average IO] = (total_logical_reads + total_logical_writes) / qs.execution_count

  ,[Total IO] = (total_logical_reads + total_logical_writes)

  ,[Execution count] = qs.execution_count

  ,[Individual Query] = SUBSTRING (qt.text,qs.statement_start_offset/2,

  (CASE WHEN qs.statement_end_offset = -1

  THEN LEN(CONVERT(NVARCHAR(MAX), qt.text)) * 2

  ELSE qs.statement_end_offset END - qs.statement_start_offset)/2)

  ,[Parent Query] = qt.text

  ,DatabaseName = DB_NAME(qt.dbid)

  FROM sys.dm_exec_query_stats qs

  CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) as qt

  ORDER BY [Average IO] DESC;

  獲得I/O統(tǒng)計(jì)

  Select wait_type, waiting_tasks_count, wait_time_ms from sys.dm_os_wait_stats where wait_type like 'PAGEIOLATCH%' order by wait_type

  查詢(xún)當(dāng)前I/O鎖