DBCC CHECKDB Dépannage de la corruption de la base de données SQL Server

Summary: DBCC CHECKDB, DBCC, réparation de base de données, base de données, base de données corrompue

This article applies to This article does not apply to This article is not tied to any specific product. Not all product versions are identified in this article.

Symptoms

Problème : La base de données MS SQL Server est corrompue et doit être réparée pour maintenir la stabilité et la cohérence.

Cause

Altération du logiciel dans la base de données MS SQL Server, les logs et les fichiers d’application.

Resolution

DBCC est un outil natif de Microsoft SQL Server conçu pour vérifier et réparer les bases de données Microsoft SQL Server.  Cet article traite de la commande DBCC CHECKDB et des options de vérification de l’intégrité logique et physique de la base de données.

Informations checkDB DBCC

DBCC CHECKDB (Transact-SQL) :

https://docs.microsoft.com/en-us/sql/t-sql/database-console-commands/dbcc-checkdb-transact-sql?view=sql-server-ver15Ce lien hypertexte renvoie à un site Web extérieur à Dell Technologies.

Étapes d’exécution de DBCC CHECKDB :

  1. Ouvrez SQL Server Studio Management
  2. Ouvrir une fenêtre de requête
  3. Saisissez « DBCC CHECKDB (Nom de la base de données) »

Résultats de l’exécution de DBCC CHECKDB
 

        4. Vérifiez près du bas des résultats de la requête pour voir les erreurs d’allocation et de cohérence. 
        5.  Si des erreurs d’allocation et de cohérence apparaissent dans les résultats, la base de données doit être restaurée à partir d’une sauvegarde ou effectuer une réparation de base de données à l’aide de DBCC CHECKDB.          

Options de réparation DBCC

  1. REPAIR_REBUILD : La commande ci-dessous place la base de données en mode permettant la réparation.
USE Master;
GO
ALTER DATABASE TSQL2012
SET SINGLE_USER
WITH ROLLBACK IMMEDIATE;
GO
DBCC CHECKDB (TSQL2012, REPAIR_REBUILD)
GO
ALTER DATABASE TSQL2012
SET MULTI_USER;
GO

Copiez la commande ci-dessous et collez-la dans la session de requête en entrant le nom de base de données correct :

--Command below performs a Database repair not allowing Data loss

USE Master;
GO
ALTER DATABASE TSQL2012
SET SINGLE_USER
WITH ROLLBACK IMMEDIATE;
GO
DBCC CHECKDB (TSQL2012,REPAIR_REBUILD)
GO
ALTER DATABASE TSQL2012
SET MULTI_USER;
GO

       2. REPAIR_ALLOW_DATA_LOSS : La commande ci-dessous effectue la réparation de la base de données et peut entraîner une perte de données pour terminer le processus de réparation.

--Command below performs a database repair that may result in data loss,
 --replace TSQL2012 with the database name of database being repaired
USE Master
GO
ALTER DATABASE TSQL2012
SET SINGLE_USER
WITH ROLLBACK IMMEDIATE
GO
DBCC CHECKDB (TSQL2012, REPAIR_ALLOW_DATA_LOSS)
GO
ALTERDATABASE TSQL2012
SET MULTI_USER
GO

Copiez la commande ci-dessous et collez-la dans la session de requête en entrant le nom de base de données correct :

Les commandes ci-dessous sont utiles si l’espace disque physique de la base de données est faible.

--Command below estimates the size TEMPDB must be to complete the DBCC CHECKDB job
USE Master;
GO
ALTER DATABASE TSQL2012
SET SINGLE_USER
WITH ROLLBACK IMMEDIATE;
GO
DBCC CHECKDB (TSQL2012, REPAIR_REBUILD)
WITH ESTIMATEONLY;
GO
ALTER DATABASE TSQL2012
SET MULTI_USER
GO

Copiez la commande ci-dessous et collez-la dans la session de requête en entrant le nom de base de données correct :

--Command below estimates the size TEMPDB must be to complete the DBCC CHECKDB job

USE Master;
GO
ALTER DATABASE TSQL2012
SET SINGLE_USER
WITH ROLLBACK IMMEDIATE;
GO
DBCC CHECKDB (TSQL2012, REPAIR_REBUILD)
WITH ESTIMATEONLY;
GO
ALTER DATABASE TSQL2012
SET MULTI_USER
GO

 

--Command below will run DBCC CHECKDB without using TEMDB and creating a DB 
--snapshot. When not using TEMPDB with a DB snapshot all data will be checked in
-- the live database not not a database snapshot.

USE Master;
GO
ALTER DATABASE TSQL2012
SET SINGLE_USER
WITH ROLLBACK IMMEDIATE;
GO
DBCC CHECKDB (TSQL2012, REPAIR_REBUILD)
WITH TABLOCK;
GO
ALTER DATABASE TSQL2012
SET MULTI_USER
GO

Copiez la commande ci-dessous, collez-la dans la session de requête et saisissez le nom de base de données approprié :

--Command below will run DBCC CHECKDB without using TEMPDB and creating a DB 
--snapshot. When not using TEMPDB with a DB snapshot all data will be checked in ---the live database not a database snapshot.

USE Master;
GO
ALTER DATABASE TSQL2012
SET SINGLE_USER
WITH ROLLBACK IMMEDIATE;
GO
DBCC CHECKDB (TSQL2012, REPAIR_REBUILD)
WITH TABLOCK;
GO
ALTER DATABASE TSQL2012
SET MULTI_USER
GO

Informations sur l’utilisation de DBCC CHECKDB

Affected Products

Dell Quickstart Data Warehouse Appliance, Prosupport for Microsoft Software
Article Properties
Article Number: 000134529
Article Type: Solution
Last Modified: 18 Mar 2025
Version:  5
Find answers to your questions from other Dell users
Support Services
Check if your device is covered by Support Services.