프로젝트 마무리 단계에서 DB 수행 속도 개선을 위해 Table의 Scan 수행 속도를 분석하고, Index 생성이 필요한 부분을 찾아내어 인덱스를 설정 할 수 있도록 도와 주는 Query Script 입니다.
SELECT TOP 100
dm_mid.database_id AS DatabaseID,
dm_migs.avg_user_impact*(dm_migs.user_seeks+dm_migs.user_scans) Avg_Estimated_Impact,
dm_migs.last_user_seek AS Last_User_Seek,
OBJECT_NAME(dm_mid.OBJECT_ID,dm_mid.database_id) AS [TableName],
'CREATE INDEX [IX_' + OBJECT_NAME(dm_mid.OBJECT_ID,dm_mid.database_id) + '_'
+ REPLACE(REPLACE(REPLACE(ISNULL(dm_mid.equality_columns,''),', ','_'),'[',''),']','')
+ CASE
WHEN dm_mid.equality_columns IS NOT NULL
AND dm_mid.inequality_columns IS NOT NULL THEN '_'
ELSE ''
END
+ REPLACE(REPLACE(REPLACE(ISNULL(dm_mid.inequality_columns,''),', ','_'),'[',''),']','')
+ ']'
+ ' ON ' + dm_mid.statement
+ ' (' + ISNULL (dm_mid.equality_columns,'')
+ CASE WHEN dm_mid.equality_columns IS NOT NULL AND dm_mid.inequality_columns
IS NOT NULL THEN ',' ELSE
'' END
+ ISNULL (dm_mid.inequality_columns, '')
+ ')'
+ ISNULL (' INCLUDE (' + dm_mid.included_columns + ')', '') AS Create_Statement
FROM sys.dm_db_missing_index_groups dm_mig
INNER JOIN sys.dm_db_missing_index_group_stats dm_migs
ON dm_migs.group_handle = dm_mig.index_group_handle
INNER JOIN sys.dm_db_missing_index_details dm_mid
ON dm_mig.index_handle = dm_mid.index_handle
WHERE dm_mid.database_ID = DB_ID()
ORDER BY Avg_Estimated_Impact DESC
'찌신이의 공부' 카테고리의 다른 글
[Visual Studio] DB 간 스키마 비교하기 (0) | 2019.12.24 |
---|---|
[MS SQL] SSMS DB 링크 생성하기 (0) | 2019.12.24 |
Visual Studio 삭제 후 재 설치 시 설치경로 수정 불가 해결방법 (0) | 2019.12.24 |
[C#.NET] PDFsharp, PDF 병합, PDF 문서 생성 및 PDF 하나로 만들기 (0) | 2019.12.24 |
[Oracle] JOIN UPDATE - 오라클 JOIN 하여 UPDATE 하기. (0) | 2019.11.25 |