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


sys.dm_db_column_store_row_group_physical_stats (Transact-SQL)

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

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

Это расширяет представление каталога sys.column_store_row_groups (Transact-SQL).

Имя столбца Тип данных 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 — НЕВИДИМая группа строк, созданная. Например:
Группа строк в columnstore невидима во время сжатия данных. После завершения сжатия переключение метаданных изменяет состояние группы строк columnstore с НЕВИДИМОго на COMPRESSED, а состояние группы строк deltastore из CLOSED в TOMBSTONE.

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

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

3 — СЖАТИЕ — группа строк, сжатая с сжатием columnstore и хранящейся в columnstore.

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

Для групп строк, которые находятся в разностном хранилище, значение равно 0.
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. РАЗЛИВ

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 млн во время операции сборки индекса. Примечание. Сборка секции с несколькими ядрами может привести к нескольким обрезкам этого типа.

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

8 — SPILLOVER: только для columnstore в таблице в памяти. Если хвост имеет > 1 миллион квалифицированных строк, последний пакет оставшихся строк сжимается, если число составляет от 100 до 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. СЛИЯНИЕ
transition_to_compressed_state_desc nvarchar(60) 1 - NOT_APPLICABLE - операция не применяется к deltastore. Кроме того, группа строк была сжата до обновления до SQL Server 2016 (13.x), в котором журнал не сохраняется.

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

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

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

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

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

7 . СЛИЯНИЕ — операция слияния объединила одну или несколько групп строк в эту группу строк, а затем выполнила сжатие columnstore.
has_vertipaq_optimization bit Оптимизация VertiPaq улучшает сжатие columnstore путем изменения порядка строк в группе строк для повышения сжатия. Эта оптимизация выполняется автоматически в большинстве случаев. Существует два случая, когда оптимизация VertiPaq не используется:
a. при перемещении разностной группы строк в columnstore и наличии одного или нескольких некластеризованных индексов в индексе columnstore. В этом случае оптимизация VertiPaq пропускается, чтобы свести к минимуму изменения индекса сопоставления;
b. для индексов columnstore в таблицах, оптимизированных для памяти.

0 = нет

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

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

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

Результаты

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

Разрешения

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

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

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

Примеры

А. Вычислите фрагментацию, чтобы решить, когда реорганизовать или перестроить индекс 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  
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;  

См. также

Представления каталога объектов (Transact-SQL)
Представления каталога (Transact-SQL)
Архитектура индексов columnstore
Часто задаваемые вопросы о запросах к системному каталогу SQL Server
sys.columns (Transact-SQL)
sys.all_columns (Transact-SQL)
sys.computed_columns (Transact-SQL)
sys.column_store_dictionaries (Transact-SQL)
sys.column_store_segments (Transact-SQL)