sys.dm_db_page_info (Transact-SQL)
S’applique à : SQL Server 2019 (15.x) Azure SQL Database Azure SQL Managed Instance
Retourne des informations sur une page de la base de données. La fonction retourne une ligne qui contient les informations d’en-tête de la page, notamment les object_id
, index_id
et partition_id
. Cette fonction rend superflue l’utilisation de DBCC PAGE
dans la plupart des cas.
Remarque
sys.dm_db_page_info
est actuellement pris en charge uniquement dans SQL Server 2019 (15.x) et versions ultérieures.
Syntaxe
sys.dm_db_page_info ( DatabaseId , FileId , PageId , Mode )
Arguments
DatabaseId | NULL | DEFAULT
ID de la base de données. DatabaseId est smallint. L’entrée autorisée est l'ID d'une base de données. La valeur par défaut est NULL, mais l’envoi d’une valeur NULL pour ce paramètre entraîne une erreur.
FileId | NULL | DEFAULT
L’ID du fichier. FileId est int. L’entrée valide est le numéro d’identification d’un fichier dans la base de données spécifiée par DatabaseId. La valeur par défaut est NULL, mais l’envoi d’une valeur NULL pour ce paramètre entraîne une erreur.
PageId | NULL | DEFAULT
L’ID de la page. PageId est int. L’entrée valide est le numéro d’identification d’une page dans le fichier spécifié par FileId. La valeur par défaut est NULL, mais l’envoi d’une valeur NULL pour ce paramètre entraîne une erreur.
Mode | NULL | DEFAULT
Détermine le niveau de détail dans la sortie de la fonction. 'LIMITED'
retourne des valeurs NULL pour toutes les colonnes de description, « DETAILED » remplit les colonnes de description. DEFAULT
est 'LIMITED'
.
Table retournée
Nom de la colonne | Type de données | Description |
---|---|---|
database_id | int | ID de la base de données. Dans la base de données Azure SQL, les valeurs sont uniques au sein d’une base de données unique ou d’un pool élastique, mais pas dans un serveur logique. |
file_id | int | ID du fichier |
page_id | int | ID page |
page_header_version | int | Version de l’en-tête de page |
page_type | int | Type de page |
page_type_desc | nvarchar(64) | Description du type de page |
page_type_flag_bits | nvarchar(64) | Type de bits d’indicateur dans l’en-tête de page |
page_type_flag_bits_desc | nvarchar(64) | Description des bits d’indicateur de type dans l’en-tête de page |
page_flag_bits | nvarchar(64) | Indicateurs dans l’en-tête de page |
page_flag_bits_desc | nvarchar (256) | Description des bits d’indicateur dans l’en-tête de page |
page_lsn | nvarchar(64) | Numéro séquentiel dans le journal / horodateur |
page_level | int | Niveau de la page dans l’index (feuille = 0) |
object_id | int | Identificateur de l’objet propriétaire de la page |
index_id | int | Identificateur de l’index (0 pour les pages de données de tas) |
partition_id | bigint | Identificateur de la partition |
alloc_unit_id | bigint | Identificateur de l'unité d'allocation |
is_encrypted | bit | Bit qui indique si la page est chiffrée ou non |
has_checksum | bit | Bit qui indique si la page a ou non une valeur de somme de contrôle |
somme de contrôle | int | Stocke la valeur de somme de contrôle utilisée pour détecter l’altération des données |
is_iam_pg | bit | Bit qui indique si la page est une page IAM ou non |
is_mixed_ext | bit | Bit qui indique si alloué dans une étendue mixte |
has_ghost_records | bit | Bit qui indique si la page contient des enregistrements fantômes Un enregistrement fantôme est un enregistrement marqué pour suppression, mais qui n’a pas encore été supprimé. |
has_version_records | bit | Bit qui indique si la page contient des enregistrements de version utilisés pour la récupération de base de données accélérée |
pfs_page_id | int | Identificateur de page de la page PFS correspondante |
pfs_is_allocated | bit | Bit qui indique si la page est marquée comme allouée dans la page PFS correspondante ou non |
pfs_alloc_percent | int | Pourcentage d’allocation comme indiqué par l’octet PFS correspondant |
pfs_status | nvarchar(64) | Octet PFS |
pfs_status_desc | nvarchar(64) | Description de l’octet PFS |
gam_page_id | int | Identificateur de page de la page GAM correspondante |
gam_status | bit | Bit qui indique si alloué dans GAM |
gam_status_desc | nvarchar(64) | Description du bit de l’état GAM |
sgam_page_id | int | Identificateur de page de la page SGAM correspondante |
sgam_status | bit | Bit qui indique si alloué dans SGAM |
sgam_status_desc | nvarchar(64) | Description du bit de l’état SGAM |
diff_map_page_id | int | Identificateur de page de la page bitmap différentielle correspondante |
diff_status | bit | Bit qui indique si l’état diff est modifié |
diff_status_desc | nvarchar(64) | Description du bit de l’état diff |
ml_map_page_id | int | Identificateur de page de la page bitmap de journalisation minimale correspondante |
ml_status | bit | Bit qui indique si la page est journalisée minimalement |
ml_status_desc | nvarchar(64) | Description du bit d’état de journalisation minimale |
prev_page_file_id | smallint | Identificateur du fichier de page précédent |
prev_page_page_id | int | Identificateur de page de la page précédente |
next_page_file_id | smallint | Identificateur du fichier de page de la page suivant |
next_page_page_id | int | Identificateur de page de la page suivante |
fixed_length | smallint | Longueur des lignes de taille fixe |
slot_count | smallint | Nombre total d’emplacements (utilisés et inutilisés) Pour une page de données, ce nombre équivaut au nombre de lignes. |
ghost_rec_count | smallint | Nombre d’enregistrements marqués comme fantômes sur la page Un enregistrement fantôme est un enregistrement marqué pour suppression, mais qui n’a pas encore été supprimé. |
free_bytes | smallint | Nombre d’octets libres sur la page |
free_data_offset | int | Décalage de l’espace libre à la fin de la zone de données |
reserved_bytes | smallint | Nombre d’octets libres réservés par toutes les transactions (si segment de mémoire) Nombre de lignes fantômes (si nœud terminal d’index) |
reserved_bytes_by_xdes_id | smallint | Espace contribué par m_xdesID à m_reservedCnt Pour des fins de débogage uniquement |
xdes_id | nvarchar(64) | Dernière transaction apportée par m_reserved Pour des fins de débogage uniquement |
Notes
La fonction de gestion dynamique sys.dm_db_page_info
retourne des informations telles que page_id
, file_id
, index_id
, object_id
et ainsi de suite, qui sont présentes dans un en-tête de page. Ces informations sont utiles pour dépanner et déboguer différentes performances (contention de verrous et de verrous) et les problèmes d’altération.
sys.dm_db_page_info
peut être utilisé à la place de l’instruction DBCC PAGE
dans de nombreux cas, mais il retourne uniquement les informations d’en-tête de page, et non le corps de la page. DBCC PAGE
est toujours nécessaire pour les cas d’usage où l’intégralité du contenu de la page est requise.
Utiliser conjointement avec d’autres DMV
L’un des cas d’usage importants de sys.dm_db_page_info
est de le joindre à d’autres DMV qui exposent des informations de page. Pour faciliter ce cas d’usage, une nouvelle colonne appelée page_resource
a été ajoutée qui expose les informations de page dans un format hexadécimal de 8 octets. Cette colonne a été ajoutée à sys.dm_exec_requests
et sys.sysprocesses
et est ajoutée à d’autres DMV à l’avenir si nécessaire.
Une nouvelle fonction, sys.fn_PageResCracker
, prend page_resource
comme entrée et génère une seule ligne qui contient database_id
, file_id
et page_id
. Cette fonction peut ensuite être utilisée pour faciliter les jointures entre sys.dm_exec_requests
ou sys.sysprocesses
et sys.dm_db_page_info
.
autorisations
Requiert l’autorisation VIEW DATABASE STATE
sur la base de données.
Autorisations pour SQL Server 2022 (et versions plus récentes)
Requiert l'autorisation VIEW DATABASE PERFORMANCE STATE sur la base de données.
Exemples
R. Afficher toutes les propriétés d’une page
La requête suivante retourne une ligne avec toutes les informations de page pour une combinaison donnée database_id
, file_id
, page_id
avec le mode par défaut (« LIMITED »)
SELECT *
FROM sys.dm_db_page_info (5, 1, 15, DEFAULT);
B. Utiliser sys.dm_db_page_info avec d’autres DMV
La requête suivante retourne une ligne par wait_resource
exposé par sys.dm_exec_requests
lorsque la ligne contient une valeur page_resource
non-null
SELECT page_info.*
FROM sys.dm_exec_requests AS d
CROSS APPLY sys.fn_PageResCracker(d.page_resource) AS r
CROSS APPLY sys.dm_db_page_info(r.db_id, r.file_id, r.page_id, 'LIMITED') AS page_info;