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


sys.dm_db_column_store_row_group_physical_stats (Transact-SQL)

Applies to: SQL Server 2016 (13.x) and later Azure SQL DatabaseAzure SQL Managed Instance

Предоставляет текущие сведения об уровне группы строк обо всех индексах columnstore в текущей базе данных.

This DMV extends the catalog view sys.column_store_row_groups.

Column name Data type Description
object_id int Идентификатор базовой таблицы.
index_id int Идентификатор этого индекса columnstore в object_id таблице.
partition_number int Идентификатор секции таблицы, содержащей row_group_id. Вы можете использовать partition_number для присоединения к этому динамическому административному представлению sys.partitions
row_group_id int Идентификатор этой группы строк. Для секционированных таблиц значение уникально в разделе.

-1 для хвоста в памяти.
delta_store_hobt_id bigint Hobt_id для группы строк в разностном хранилище.

NULL Значение , если группа строк не хранится в разностном хранилище.

NULL для хвоста таблицы в памяти.
state tinyint Связанный state_descriptionномер идентификатора.

0 = INVISIBLE
1= OPEN
2 = CLOSED
3 = COMPRESSED
4 = TOMBSTONE

COMPRESSED — единственное состояние, которое применяется к таблицам в памяти.
state_desc nvarchar(60) Описание состояния группы строк:

0 - INVISIBLE — созданная группа строк. For example:

Группа строк в columnstore находится INVISIBLE во время сжатия данных. После завершения сжатия переключение метаданных изменяет состояние группы строк columnstore в INVISIBLECOMPRESSEDзначение , а состояние группы строк deltastore — на CLOSEDTOMBSTONE.

1 - OPEN — группа строк deltastore, принимаюющая новые строки. Открытая группа строк по-прежнему находится в формате rowstore и не сжимается до формата columnstore.

2 - CLOSED — Группа строк в разностном хранилище, содержащая максимальное количество строк, и ожидает, чтобы процесс перемещения кортежей сжимал его в columnstore.

3 - COMPRESSED — группа строк, сжатая с сжатием columnstore и хранящейся в columnstore.

4 - TOMBSTONE — Группа строк, которая ранее находилась в deltastore и больше не используется.
total_rows bigint Количество строк, которые физически хранятся в группе строк. Для сжатых групп строк. Включает строки, помеченные как удаленные.
deleted_rows bigint Количество строк, физически хранящихся в сжатой группе строк и помеченных для удаления.

0 для групп строк, входящих в разностное хранилище.

Для некластеризованных индексов columnstore это значение не включает удаленные строки, хранящиеся в буфере удаления. For more information, and to find the number of deleted rows in the delete buffer, see sys.internal_partitions.
size_in_bytes bigint Объединенный размер (в байтах) всех страниц в этой группе строк. Этот размер не включает размер, необходимый для хранения метаданных или общих словарей.
trim_reason tinyint Причина, которая активировала COMPRESSED группу строк, меньше максимального числа строк.

0 - UNKNOWN_UPGRADED_FROM_PREVIOUS_VERSION
1 - NO_TRIM
2 - BULKLOAD
3 - REORG
4 - DICTIONARY_SIZE
5 - MEMORY_LIMITATION
6 - RESIDUAL_ROW_GROUP
7 - STATS_MISMATCH
8 - SPILLOVER
9 - AUTO_MERGE
trim_reason_desc nvarchar(60) trim_reasonОписание .

0 - UNKNOWN_UPGRADED_FROM_PREVIOUS_VERSION: произошло при обновлении предыдущей версии SQL Server.

1 - NO_TRIM: группа строк не была обрезана. Группа строк была сжата с максимальным числом строк 1 048 576. Число строк может быть меньше, если подмножество строк было удалено после закрытия разностной группы строк

2 - BULKLOAD: размер пакета массовой загрузки ограничивает количество строк.

3 - REORG: принудительное сжатие в REORG составе команды.

4 - DICTIONARY_SIZE: размер словаря вырос слишком велик, чтобы сжать все строки вместе.

5 - MEMORY_LIMITATION: недостаточно доступной памяти для сжатия всех строк вместе.

6 - RESIDUAL_ROW_GROUP: закрыто в рамках последней группы строк со строками < 1 млн во время операции сборки индекса.

Note: A partition build with multiple cores can result in more than one trim of this type.

7 - STATS_MISMATCH: только для columnstore в таблице в памяти. Если статистика неправильно указала >= 1 миллион квалифицированных строк в хвосте, но мы обнаружили меньше, сжатые группы строк будут иметь < 1 миллион строк

8 - SPILLOVER: только для columnstore в таблице в памяти. Если хвост имеет > 1 миллион квалифицированных строк, последний пакет оставшихся строк сжимается, если число составляет от 100 000 до 1 миллиона

9 - AUTO_MERGE: операция слияния Кортежа Mover, выполняемая в фоновом режиме, консолидированная одна или несколько групп строк в эту группу строк.
transition_to_compressed_state tinyint Показывает, как эта группа строк была перемещена из deltastore в сжатое состояние в columnstore.

1 - NOT_APPLICABLE
2 - INDEX_BUILD
3 - TUPLE_MOVER
4 - REORG_NORMAL
5 - REORG_FORCED
6 - BULKLOAD
7 - MERGE
transition_to_compressed_state_desc nvarchar(60) 1 - NOT_APPLICABLE — операция не применяется к deltastore. Кроме того, группа строк была сжата до обновления до SQL Server 2016 (13.x), в котором журнал не сохраняется.

2 - INDEX_BUILD — создание индекса или перестроение индекса сжатой группы строк.

3 - TUPLE_MOVER — Перемещение кортежа, выполняемого в фоновом режиме, сжимает группу строк. Перемещение кортежей происходит после изменения состояния группы строк на OPENCLOSED.

4 - REORG_NORMAL — операция реорганизации, ALTER INDEX ... REORGперемещенная CLOSED группа строк из deltastore в columnstore. Это произошло до того, как кортеж-перемещение было время переместить группу строк.

5 - REORG_FORCED — Эта группа строк была открыта в deltastore и была вынуждена в columnstore, прежде чем она имела полное количество строк.

6 - BULKLOAD — операция массового загрузки сжимает группу строк непосредственно без использования deltastore.

7 - MERGE — Операция слияния объединила одну или несколько групп строк в эту группу строк, а затем выполнила сжатие columnstore.
has_vertipaq_optimization bit Оптимизация VertiPaq улучшает сжатие columnstore путем изменения порядка строк в группе строк для повышения сжатия. Эта оптимизация выполняется автоматически в большинстве случаев. Существует два случая, когда оптимизация VertiPaq не используется:

a. при перемещении разностной группы строк в columnstore и наличии одного или нескольких некластеризованных индексов в индексе columnstore— в этом случае оптимизация VertiPaq пропускается, чтобы свести к минимуму изменения индекса сопоставления;

b. для индексов columnstore в таблицах, оптимизированных для памяти.

0 = Нет
1 = Да
generation bigint Поколение групп строк, связанное с этой группой строк.
created_time datetime2 Время создания этой группы строк.

NULL — для индекса columnstore в таблице в памяти.
closed_time datetime2 Время времени закрытия этой группы строк.

NULL — для индекса columnstore в таблице в памяти.

Results

Возвращает одну строку для каждой группы строк в текущей базе данных.

Permissions

Требуется CONTROL разрешение на таблицу и VIEW DATABASE STATE разрешение на базу данных.

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

Необходимо разрешение VIEW DATABASE PERFORMANCE STATE на базу данных.

Examples

A. Вычисление фрагментации, чтобы определить, когда реорганизовать или перестроить индекс columnstore

Для индексов columnstore процент удаленных строк является хорошей мерой фрагментации в группе строк. Если фрагментация составляет 20 % или больше, удалите удаленные строки. Дополнительные примеры см. в статье "Оптимизация обслуживания индекса", чтобы повысить производительность запросов и сократить потребление ресурсов.

Этот пример объединяется sys.dm_db_column_store_row_group_physical_stats с другими системными таблицами, а затем вычисляет Fragmentation столбец как оценку эффективности каждой группы строк в текущей базе данных. Чтобы найти информацию о одной таблице, удалите дефисы комментариев перед WHERE предложением и укажите имя таблицы.

SELECT i.object_id,
       object_name(i.object_id) AS TableName,
       i.name AS IndexName,
       i.index_id,
       i.type_desc,
       CSRowGroups.*,
       100 * (ISNULL(deleted_rows, 0)) / NULLIF (total_rows, 0) AS 'Fragmentation'
FROM sys.indexes AS i
     INNER JOIN sys.dm_db_column_store_row_group_physical_stats AS CSRowGroups
         ON i.object_id = CSRowGroups.object_id
        AND i.index_id = CSRowGroups.index_id
-- WHERE object_name(i.object_id) = 'table_name'
ORDER BY object_name(i.object_id), i.name, row_group_id;