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


sys.dm_db_partition_stats (Transact-SQL)

Применимо: SQL Server База данных SQL Azure Управляемый экземпляр SQL Azure azure Synapse Analytics Analytics Platform System (PDW)

Возвращает страницу и сведения о количестве строк для всех секций текущей базы данных.

Примечание.

Чтобы вызвать это из Azure Synapse Analytics или Analytics Platform System (PDW), используйте имя sys.dm_pdw_nodes_db_partition_stats. Partition_id sys.dm_pdw_nodes_db_partition_stats отличаются от partition_id в sys.partitions представлении каталога для Azure Synapse Analytics. Этот синтаксис не поддерживается бессерверным пулом SQL в Azure Synapse Analytics.

Имя столбца Тип данных Description
partition_id bigint Идентификатор секции. Является уникальным в пределах базы данных. Это то же значение, что partition_id и в sys.partitions представлении каталога, за исключением Azure Synapse Analytics.
object_id int Идентификатор таблицы или индексированного представления, в которое входит данная секция.
index_id int Идентификатор кучи или индекса, в который входит данная секция.

0 = куча;
1 = Кластеризованный индекс.
> 1 = некластеризованный индекс
partition_number int Номер секции внутри индекса или кучи (нумерация начинается с 1).
in_row_data_page_count bigint Количество страниц, используемых для хранения данных, содержащихся в строках данной секции. Если секция является частью кучи, то данное значение отображает количество страниц данных в куче. Если секция является частью индекса, то данное значение отображает количество страниц на конечном уровне. (Небезопасные страницы в дереве B+ не включены в число.) Страницы IAM (карта распределения индекса) не включаются в любом случае. Всегда 0 для оптимизированного для памяти xVelocity индекса columnstore.
in_row_used_page_count bigint Количество страниц, используемых для хранения и управления данными, содержащимися в строках данной секции. Это число включает небезопасные страницы дерева B+, страницы IAM и все страницы, включенные в столбец in_row_data_page_count . Всегда равно 0 для индекса columnstore.
in_row_reserved_page_count bigint Общее количество страниц, зарезервированных для хранения и управления данными в данной секции (учитываются как используемые, так и не используемые страницы). Всегда равно 0 для индекса columnstore.
lob_used_page_count bigint Количество страниц, используемых для хранения текста вне строк, ntext, image, varchar(max),nvarchar(max), varbinary(max)и xml-столбцов в секции. IAM-страницы учитываются.

Количество больших объектов (LOB), используемых для хранения и управления данными индекса columnstore в секции.
lob_reserved_page_count bigint Общее количество страниц, зарезервированных для хранения и управления текстом вне строки, ntext, image, varchar(max), nvarchar(max), varbinary(max)и xml-столбцов в секции независимо от того, используются ли страницы. IAM-страницы учитываются.

Общее количество больших объектов (LOB), зарезервированных для хранения и управления индексом columnstore в секции.
row_overflow_used_page_count bigint Количество страниц, используемых для хранения и управления varchar строки переполнения строк, nvarchar, varbinary и sql_variant столбцов в разделе. IAM-страницы учитываются.

Всегда равно 0 для индекса columnstore.
row_overflow_reserved_page_count bigint Общее количество страниц, зарезервированных для хранения и управления varchar, nvarchar, varbinary и sql_variant столбцов в секции независимо от того, используются ли страницы. IAM-страницы учитываются.

Всегда равно 0 для индекса columnstore.
used_page_count bigint Общее число страниц, используемых в секции. Вычисляется как in_row_used_page_count + lob_used_page_count row_overflow_used_page_count. +
reserved_page_count bigint Общее число страниц, зарезервированных в секции. Вычисляется как in_row_reserved_page_count + lob_reserved_page_count row_overflow_reserved_page_count. +
row_count bigint Приблизительное количество строк в секции.
pdw_node_id int Область применения: Azure Synapse Analytics, Analytics Platform System (PDW)

Идентификатор узла, на который находится данное распределение.
distribution_id int Область применения: Azure Synapse Analytics, Analytics Platform System (PDW)

Уникальный числовой идентификатор, связанный с распределением.

Замечания

В sys.dm_db_partition_stats динамическом представлении управления (DMV) отображаются сведения о пространстве, используемом для хранения бизнес-данных в строке и управления данными бизнес-аналитики строк, а также данные о переполнении строк для всех секций в базе данных. Для каждой секции отображается одна строка.

Количество, на котором основаны выходные данные, кэшируются в памяти или хранятся на диске в различных системных таблицах.

Данные в строках, данные LOB, а также данные строки, превышающие размер страницы, представляют собой три типа единиц распределения, из которых состоит секция. Из представления каталога sys.allocation_units можно запрашивать метаданные по каждой единице распределения базы данных.

Если куча или индекс не имеют делений, то они состоят из одной секции (с номером 1); поэтому для каждой такой кучи или индекса возвращается только одна строка. Из представления каталога sys.partitions можно запрашивать метаданные по каждой секции таблиц и индексов базы данных.

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

Разрешения

Требуется VIEW DATABASE STATE и VIEW DEFINITION разрешения для запроса динамического административного sys.dm_db_partition_stats представления. Более подробные сведения о разрешениях динамических административных представлений см. в разделе Динамические административные представления и функции (Transact-SQL).

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

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

Примеры

А. Возвращает все счетчики для всех секций всех индексов и куч в базе данных.

В следующем примере показаны все счетчики для всех секций всех индексов и куч в базе данных AdventureWorks2022.

USE AdventureWorks2022;  
GO  
SELECT * FROM sys.dm_db_partition_stats;  
GO  

B. Возвращает все счетчики для всех секций таблицы и его индексов.

В следующем примере выводятся результаты подсчета для всех секций таблицы HumanResources.Employee и ее индексов.

USE AdventureWorks2022;  
GO  
SELECT * FROM sys.dm_db_partition_stats   
WHERE object_id = OBJECT_ID('HumanResources.Employee');  
GO  

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

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

USE AdventureWorks2022;  
GO  
SELECT SUM(used_page_count) AS total_number_of_used_pages,   
    SUM (row_count) AS total_number_of_rows   
FROM sys.dm_db_partition_stats  
WHERE object_id=OBJECT_ID('HumanResources.Employee')    AND (index_id=0 or index_id=1);  
GO