Поделиться через


sys.dm_db_missing_index_columns (Transact-SQL)

Область применения: SQL Server База данных SQL Azure Управляемый экземпляр SQL Azure

Возвращает сведения о столбцах таблицы базы данных, которые отсутствуют в индексе. sys.dm_db_missing_index_columns — это динамическая функция управления.

Синтаксис

sys.dm_db_missing_index_columns(index_handle)  

Аргументы

index_handle
Целочисленное значение, уникальным образом идентифицирующее отсутствующий индекс. Его можно получить из следующих объектов DMO.

sys.dm_db_missing_index_details (Transact-SQL)

sys.dm_db_missing_index_groups (Transact-SQL)

Возвращаемая таблица

Имя столбца Тип данных Description
column_id int Идентификатор столбца.
column_name sysname Имя столбца таблицы.
column_usage varchar(20) Способ использования столбца запросом. Возможные значения и их описания:

Равенство: столбец вносит вклад в предикат, который выражает равенство формы:
table.column = constant_value

INEQUALITY: столбец вносит вклад в предикат, который выражает неравенство, например предикат формы: table.column>constant_value. Любой оператор сравнения, кроме «=», выражает неравенство.

INCLUDE: столбец не используется для оценки предиката, но используется по другой причине, например для покрытия запроса.

Замечания

Информация, возвращаемая обновлением sys.dm_db_missing_index_columns , когда запрос оптимизирован оптимизатором запросов и не сохраняется. Отсутствующие сведения о индексе хранятся только до перезапуска ядра СУБД. Администраторы базы данных должны периодически делать резервные копии сведений об отсутствующих индексах, чтобы сохранить их после перезагрузки сервера. Узнать время последнего запуска ядра СУБД можно в столбце sqlserver_start_time из sys.dm_os_sys_info.

Согласованность транзакций

Если транзакция создает или удаляет таблицу, то строки, содержащие сведения отсутствующих индексов об удаленных объектах, удаляются из данного объекта DMO, сохраняя согласованность транзакций.

Разрешения

Пользователям необходимо предоставить разрешение VIEW SERVER STATE или любое разрешение, которое подразумевает разрешение VIEW SERVER STATE, чтобы выполнить запрос к этой функции динамического управления.

Разрешения для SQL Server 2022 и более поздних версий

Требуется разрешение VIEW SERVER PERFORMANCE STATE на сервере.

Примеры

В следующем примере выполняется запрос к таблице Address, а затем выполняется запрос с использованием динамического административного представления sys.dm_db_missing_index_columns для возврата столбцов таблицы, отсутствующих в индексе.

USE AdventureWorks2022;  
GO  
SELECT City, StateProvinceID, PostalCode  
FROM Person.Address  
WHERE StateProvinceID = 9;  
GO  
SELECT mig.*, statement AS table_name,  
    column_id, column_name, column_usage  
FROM sys.dm_db_missing_index_details AS mid  
CROSS APPLY sys.dm_db_missing_index_columns (mid.index_handle)  
INNER JOIN sys.dm_db_missing_index_groups AS mig ON mig.index_handle = mid.index_handle  
ORDER BY mig.index_group_handle, mig.index_handle, column_id;  
GO  

Отсутствующие предложения по индексу должны сочетаться, если это возможно, с существующими индексами в текущей базе данных. Узнайте, как применять эти предложения в настройке некластеризованных индексов с отсутствующими предложениями индекса.

Следующие шаги

Дополнительные сведения о функции отсутствующих индексов см. в следующих статьях: