backupset (Transact-SQL)
S’applique à : SQL Server Azure SQL Managed Instance Analytics Platform System (PDW)
Contient une ligne pour chaque jeu de sauvegarde. Un jeu de sauvegarde contient la sauvegarde issue d’une opération de sauvegarde réussie unique. Les instructions RESTORE, RESTORE FILELISTONLY, RESTORE HEADERONLY et RESTORE VERIFYONLY fonctionnent sur un jeu de sauvegarde unique dans le jeu de médias sur la ou les unités de sauvegarde spécifiées.
Cette table est stockée dans la msdb
base de données.
Nom de la colonne | Type de données | Description |
---|---|---|
backup_set_id | int | Numéro d'identification unique du jeu de sauvegardes Identité, clé primaire. |
backup_set_uuid | uniqueidentifier | Numéro d'identification unique du jeu de sauvegardes |
media_set_id | int | Numéro d'identification unique du support de sauvegarde contenant le jeu de sauvegardes. Références backupmediaset(media_set_id). |
first_family_number | tinyint | Numéro de famille du support qui est le premier du jeu de sauvegardes. Sa valeur peut être NULL. |
first_media_number | smallint | Numéro du support qui est le premier du jeu de sauvegardes. Sa valeur peut être NULL. |
last_family_number | tinyint | Numéro de famille du support qui est le dernier du jeu de sauvegardes. Sa valeur peut être NULL. |
last_media_number | smallint | Numéro du support qui est le dernier du jeu de sauvegardes. Sa valeur peut être NULL. |
catalog_family_number | tinyint | Numéro de famille du support contenant le début du répertoire du jeu de sauvegardes. Sa valeur peut être NULL. |
catalog_media_number | smallint | Numéro du support de sauvegardes contenant le début du répertoire du jeu de sauvegardes. Sa valeur peut être NULL. |
position | int | Position du jeu de sauvegardes utilisée lors de la restauration pour localiser les fichiers et le jeu de sauvegardes appropriés. Sa valeur peut être NULL. For more information, see FILE in BACKUP (Transact-SQL). |
expiration_date | datetime | Date et heure d'expiration du jeu de sauvegardes. Sa valeur peut être NULL. |
software_vendor_id | int | Numéro d'identification du fournisseur du logiciel qui a écrit l'en-tête de support de sauvegardes Sa valeur peut être NULL. |
nom | nvarchar(128) | Nom du jeu de sauvegardes. Sa valeur peut être NULL. |
description | nvarchar(255) | Description du jeu de sauvegardes. Sa valeur peut être NULL. |
user_name | nvarchar(128) | Nom de l'utilisateur effectuant la sauvegarde Sa valeur peut être NULL. |
software_major_version | tinyint | Numéro de version principale de Microsoft SQL Server. Sa valeur peut être NULL. |
software_minor_version | tinyint | Numéro de version secondaire de SQL Server. Sa valeur peut être NULL. |
software_build_version | smallint | Numéro de build de SQL Server. Sa valeur peut être NULL. |
time_zone | smallint | Différence entre l’heure locale (où l’opération de sauvegarde est effectuée) et le temps universel coordonné (UTC) dans les intervalles de 15 minutes à l’aide des informations de fuseau horaire au moment où l’opération de sauvegarde a démarré. Les valeurs peuvent être comprises entre - 48 et + 48 incluses. La valeur 127 signifie inconnu. Par exemple, -20 correspond à l'heure de l'Est (USA) soit 5 heures après l'heure universelle UTC. Sa valeur peut être NULL. |
mtf_minor_version | tinyint | Numéro de la version secondaire du format de bande Microsoft. Sa valeur peut être NULL. |
first_lsn | numeric(25,0) | Numéro séquentiel dans le journal correspondant au premier enregistrement ou à l'enregistrement le plus ancien du journal dans le jeu de sauvegardes Sa valeur peut être NULL. |
last_lsn | numeric(25,0) | Numéro séquentiel dans le journal correspondant à l'enregistrement du journal suivant après le jeu de sauvegarde. Sa valeur peut être NULL. |
checkpoint_lsn | numeric(25,0) | Numéro séquentiel dans le journal correspondant à l'enregistrement à partir duquel le rétablissement doit démarrer. Sa valeur peut être NULL. |
database_backup_lsn | numeric(25,0) | Numéro séquentiel dans le journal correspondant à la sauvegarde complète la plus récente de la base de données. Sa valeur peut être NULL. database_backup_lsn constitue le « début du point de contrôle » déclenché lors du démarrage de la sauvegarde. Ce LSN coïncide avec first_lsn si la sauvegarde est effectuée lorsque la base de données est inactive et qu'aucune réplication n'a été configurée. |
database_creation_date | datetime | Date et heure de création de la base de données. Sa valeur peut être NULL. |
backup_start_date | datetime | Date et heure de début de la sauvegarde Sa valeur peut être NULL. |
backup_finish_date | datetime | Date et heure de fin de la sauvegarde Sa valeur peut être NULL. |
type | char(1) | Type de sauvegarde. Valeurs possibles : D = Base de données I = Base de données différentielle L = Journal F = Fichier ou groupe de fichiers G =Fichier différentiel P = Partiel Q = Partielle différentielle Sa valeur peut être NULL. |
sort_order | smallint | Ordre de tri utilisé par le serveur effectuant la sauvegarde. Sa valeur peut être NULL. Pour plus d’informations sur les ordres de tri, consultez Prise en charge d’Unicode et du classement. |
code_page | smallint | Page de codes du serveur effectuant la sauvegarde. Sa valeur peut être NULL. Pour plus d’informations sur les pages de codes, consultez Prise en charge d’Unicode et du classement. |
compatibility_level | tinyint | Paramètres définissant le niveau de compatibilité de la base de données. Valeurs possibles : 90 = SQL Server 2005 (9.x) 100 = SQL Server 2008 (10.0.x) 110 = SQL Server 2012 (11.x) 120 = SQL Server 2014 (12.x) 130 = SQL Server 2016 (13.x) 140 = SQL Server 2017 (14.x) 150 = SQL Server 2019 (15.x) 160 = SQL Server 2022 (16.x) Sa valeur peut être NULL. Pour plus d’informations sur les niveaux de compatibilité, consultez Niveau de compatibilité ALTER DATABASE (Transact-SQL). |
database_version | int | Numéro de version de la base de données. Sa valeur peut être NULL. |
backup_size | numeric(20,0) | Taille du jeu de sauvegardes en octets. Sa valeur peut être NULL. Pour les sauvegardes VSS, backup_size est une valeur estimée. |
database_name | nvarchar(128) | Nom de la base de données impliquée dans la sauvegarde. Sa valeur peut être NULL. |
server_name | nvarchar(128) | Nom du serveur exécutant l’opération de sauvegarde de SQL Server. Sa valeur peut être NULL. |
machine_name | nvarchar(128) | Nom de l'ordinateur sur lequel SQL Serverest exécuté. Sa valeur peut être NULL. |
flags | int | Dans SQL Server, la colonne indicateurs a été déconseillée et est remplacée par les colonnes de bits suivantes : has_bulk_logged_data is_snapshot is_readonly is_single_user has_backup_checksums is_damaged begins_log_chain has_incomplete_metadata is_force_offline is_copy_only Sa valeur peut être NULL. Dans des jeux de sauvegarde à partir de versions antérieures de SQL Server, bits d'indicateur : 1 = La sauvegarde contient des données consignées de façon minimale. 2 = WITH SNAPSHOT a été utilisé. 4 = La base de données était accessible en lecture seule au moment de la sauvegarde. 8 = La base de données était en mode mono-utilisateur au moment de la sauvegarde. |
unicode_locale | int | Paramètres régionaux Unicode. Sa valeur peut être NULL. |
unicode_compare_style | int | Style de comparaison Unicode. Sa valeur peut être NULL. |
collation_name | nvarchar(128) | Nom du classement. Sa valeur peut être NULL. |
Is_password_protected | bit | Jeu de sauvegardes protégé par mot de passe : 0 = Non protégé 1 = Protégé |
recovery_model | nvarchar(60) | Mode de récupération de la base de données : FULL BULK-LOGGED SIMPLE |
has_bulk_logged_data | bit | 1 = La sauvegarde contient des données journalisées en bloc. |
is_snapshot | bit | 1 = La sauvegarde a été réalisée à l'aide de l'option SNAPSHOT. |
is_readonly | bit | 1 = La base de données était accessible en lecture seule au moment de la sauvegarde. |
is_single_user | bit | 1 = La base de données était en mode mono-utilisateur lors de la sauvegarde. |
has_backup_checksums | bit | 1 = La sauvegarde contient des sommes de contrôle de sauvegarde. |
is_damaged | bit | 1 = Des dommages ont été détectés pour la base de données lors de la création de cette sauvegarde. L'opération de sauvegarde a dû continuer malgré les erreurs. |
begins_log_chain | bit | 1 = Il s'agit de la première d'une chaîne continue de sauvegardes journalisées. Une séquence de journaux démarre par la première sauvegarde journalisée effectuée après la création de la base de données, ou lorsqu'elle passe du mode de récupération simple à complète ou utilisant les journaux de transactions. |
has_incomplete_metadata | bit | 1 = Sauvegarde de la fin du journal avec des métadonnées incomplètes. Pour plus d’informations, consultez Sauvegardes de la fin du journal (SQL Server). |
is_force_offline | bit | 1 = La base de données est passée en mode hors connexion à l'aide de l'option NORECOVERY lors de la sauvegarde. |
is_copy_only | bit | 1 = Sauvegarde de copie unique. Pour plus d’informations, consultez Sauvegardes de copie uniquement (SQL Server). |
first_recovery_fork_guid | uniqueidentifier | ID du branchement de récupération de début. Cela correspond à FirstRecoveryForkID de RESTORE HEADERONLY. Pour les sauvegardes de données, first_recovery_fork_guid équivaut à last_recovery_fork_guid. |
last_recovery_fork_guid | uniqueidentifier | ID du branchement de récupération de fin. Cela correspond à RecoveryForkID de RESTORE HEADERONLY. Pour les sauvegardes de données, first_recovery_fork_guid équivaut à last_recovery_fork_guid. |
fork_point_lsn | numeric(25,0) | Si first_recovery_fork_guid n'équivaut pas à last_recovery_fork_guid, il s'agit du numéro séquentiel dans le journal du point de duplication (fork). Dans le cas contraire, la valeur est NULL. |
database_guid | uniqueidentifier | ID unique de la base de données. Cela correspond à BindingID de RESTORE HEADERONLY. Lors de la restauration de la base de données, une nouvelle valeur est attribuée. |
family_guid | uniqueidentifier | ID unique de la base de données d'origine lors de sa création. Cette valeur demeure identique lors de la restauration de la base de données, même sous un nom différent. |
differential_base_lsn | numeric(25,0) | Numéro de séquence d'enregistrement de base pour les sauvegardes différentielles. Pour une sauvegarde différentielle unique, les modifications avec des LSN supérieurs ou égaux à differential_base_lsn sont incluses dans la sauvegarde différentielle. Pour une sauvegarde différentielle multibase, la valeur est NULL, tandis que le LSN de base doit être déterminé au niveau du fichier (consultez backupfile (Transact-SQL)). Pour les types de sauvegarde non différentiels, la valeur est toujours NULL. |
differential_base_guid | uniqueidentifier | Pour une sauvegarde différentielle unique, cette valeur constitue l'identificateur unique de la base différentielle. Pour les sauvegardes différentielles multiples, cette valeur est NULL, tandis que la base différentielle doit être déterminée au niveau du fichier. Pour les types de sauvegarde non différentiels, la valeur est NULL. |
compressed_backup_size | Numeric(20,0) | Nombre total d'octets de la sauvegarde stocké sur le disque. Pour calculer le taux de compression, utilisez compressed_backup_size et backup_size. Pendant une msdb mise à niveau, cette valeur est définie sur NULL. ce qui indique une sauvegarde non compressée. |
key_algorithm | nvarchar(32) | Algorithme de chiffrement utilisé pour chiffrer la sauvegarde. La valeur NO_Encryption indique que la sauvegarde n'est pas chiffrée. |
encryptor_thumbprint | varbinary(20) | Empreinte numérique du chiffreur pouvant être utilisé pour rechercher un certificat ou la clé asymétrique dans la base de données. Si la sauvegarde n'est pas chiffrée, cette valeur est NULL. |
encryptor_type | nvarchar(32) | Type de chiffreur utilisé : certificat ou clé asymétrique. Si la sauvegarde n'est pas chiffrée, cette valeur est NULL. |
last_valid_restore_time | datetime | Horodatage du dernier enregistrement du journal des transactions inclus dans la sauvegarde du journal des transactions, pour les enregistrements de journal qui comportent un horodatage. Aide à construire des plans de restauration en vous aidant à trouver la dernière sauvegarde du journal à restaurer lorsque la STOPAT clause est spécifiée dans l’instruction RESTORE LOG . Cette sauvegarde de journal a la last_valid_restore_time strictement supérieure à la durée spécifiée dans la STOPAT clause. Introduite dans SQL Server 2022 (16.x). |
compression_algorithm | nvarchar(32) | Algorithme de compression utilisé lors de la création de la sauvegarde SQL Server. Introduite dans SQL Server 2022 (16.x). La valeur par défaut est MS_XPRESS . Pour plus d’informations, consultez COMPRESSION DE SAUVEGARDE et accélération intégrée et déchargement. |
Notes
RESTORE VERIFYONLY FROM <backup_device> WITH LOADHISTORY
remplit la colonne de labackupmediaset
table avec les valeurs appropriées de l’en-tête media-set.- Pour réduire le nombre de lignes dans cette table et dans d'autres tables de sauvegarde et d'historique, exécutez la procédure stockée sp_delete_backuphistory.
- Pour SQL Managed Instance, consultez la transparence des sauvegardes et comment surveiller les sauvegardes.
Exemples
Interroger l’historique de sauvegarde
La requête suivante retourne les informations de sauvegarde réussies des deux derniers mois.
SELECT bs.database_name,
backuptype = CASE
WHEN bs.type = 'D' AND bs.is_copy_only = 0 THEN 'Full Database'
WHEN bs.type = 'D' AND bs.is_copy_only = 1 THEN 'Full Copy-Only Database'
WHEN bs.type = 'I' THEN 'Differential database backup'
WHEN bs.type = 'L' THEN 'Transaction Log'
WHEN bs.type = 'F' THEN 'File or filegroup'
WHEN bs.type = 'G' THEN 'Differential file'
WHEN bs.type = 'P' THEN 'Partial'
WHEN bs.type = 'Q' THEN 'Differential partial'
END + ' Backup',
CASE bf.device_type
WHEN 2 THEN 'Disk'
WHEN 5 THEN 'Tape'
WHEN 7 THEN 'Virtual device'
WHEN 9 THEN 'Azure Storage'
WHEN 105 THEN 'A permanent backup device'
ELSE 'Other Device'
END AS DeviceType,
bms.software_name AS backup_software,
bs.recovery_model,
bs.compatibility_level,
BackupStartDate = bs.Backup_Start_Date,
BackupFinishDate = bs.Backup_Finish_Date,
LatestBackupLocation = bf.physical_device_name,
backup_size_mb = CONVERT(DECIMAL(10, 2), bs.backup_size / 1024. / 1024.),
compressed_backup_size_mb = CONVERT(DECIMAL(10, 2), bs.compressed_backup_size / 1024. / 1024.),
database_backup_lsn, -- For tlog and differential backups, this is the checkpoint_lsn of the FULL backup it is based on.
checkpoint_lsn,
begins_log_chain,
bms.is_password_protected
FROM msdb.dbo.backupset bs
LEFT JOIN msdb.dbo.backupmediafamily bf
ON bs.[media_set_id] = bf.[media_set_id]
INNER JOIN msdb.dbo.backupmediaset bms
ON bs.[media_set_id] = bms.[media_set_id]
WHERE bs.backup_start_date > DATEADD(MONTH, - 2, sysdatetime()) --only look at last two months
ORDER BY bs.database_name ASC,
bs.Backup_Start_Date DESC;
Étapes suivantes
- BACKUP (Transact-SQL)
- Instructions RESTORE (Transact-SQL)
- Tables de sauvegarde et de restauration (Transact-SQL)
- backupfile (Transact-SQL)
- backupfilegroup (Transact-SQL)
- backupmediafamily (Transact-SQL)
- backupmediaset (Transact-SQL)
- Erreurs de support possibles pendant les opérations de sauvegarde et restauration (SQL Server)
- Jeux de supports, familles de supports et jeux de sauvegarde (SQL Server)
- Modes de récupération (SQL Server)
- RESTORE HEADERONLY (Transact-SQL)
- Tables de sauvegarde et de restauration (Transact-SQL)