DBCC CHECKDB (Transact-SQL)
Se aplica a:SQL ServerAzure SQL DatabaseAzure SQL Managed Instance
Comprueba la integridad física y lógica de todos los objetos de la base de datos especificada mediante la realización de las siguientes operaciones:
Ejecuta DBCC CHECKALLOC en la base de datos.
Ejecuta DBCC CHECKTABLE en todas las tablas y vistas de la base de datos.
Ejecuta DBCC CHECKCATALOG en la base de datos.
Valida el contenido de cada vista indizada de la base de datos.
Valida la coherencia de nivel de vínculo entre los metadatos de la tabla y los directorios y archivos del sistema de archivos al almacenar datos varbinary(max) en el sistema de archivos mediante FILESTREAM.
Valida los datos de Service Broker en la base de datos.
Esto significa que los comandos DBCC CHECKALLOC
, DBCC CHECKTABLE
o DBCC CHECKCATALOG
y el comando DBCC CHECKDB
no tienen que ejecutarse por separado. Para obtener información más detallada sobre las comprobaciones que realizan estos comandos, vea sus descripciones.
DBCC CHECKDB
se admite en bases de datos que contienen tablas optimizadas para memoria, pero la validación solo se produce en tablas basadas en disco. Sin embargo, como parte de la copia de seguridad y recuperación de la base de datos, se realiza una validación de CHECKSUM
para archivos en grupos de archivos optimizados para memoria.
Puesto que las opciones de reparación de DBCC no están disponibles para las tablas optimizadas para memoria, debe hacer periódicamente copia de seguridad de las bases de datos y probar dichas copias. Si se producen problemas de integridad de datos en una tabla optimizada para memoria, debe restaurar desde la última copia de seguridad válida conocida.
Convenciones de sintaxis de Transact-SQL
Sintaxis
DBCC CHECKDB
[ [ ( database_name | database_id | 0
[ , NOINDEX
| , { REPAIR_ALLOW_DATA_LOSS | REPAIR_FAST | REPAIR_REBUILD } ]
) ]
[ WITH
{
[ ALL_ERRORMSGS ]
[ , EXTENDED_LOGICAL_CHECKS ]
[ , NO_INFOMSGS ]
[ , TABLOCK ]
[ , ESTIMATEONLY ]
[ , { PHYSICAL_ONLY | DATA_PURITY } ]
[ , MAXDOP = number_of_processors ]
}
]
]
Argumentos
database_name | database_id | 0
Nombre o id. de la base de datos para la que se van a ejecutar comprobaciones de integridad. Si no se especifica o se especifica 0, se utiliza la base de datos actual. Los nombres de las bases de datos deben cumplir las reglas de los identificadores.
NOINDEX
Especifica que no se realizan comprobaciones intensivas de índices no clúster para las tablas de usuario. Esta opción reduce el tiempo total de ejecución. NOINDEX
no afecta a las tablas del sistema, porque las comprobaciones de integridad siempre se realizan en los índices de las tablas del sistema.
REPAIR_ALLOW_DATA_LOSS | REPAIR_FAST | REPAIR_REBUILD
Especifica que DBCC CHECKDB
repara los errores encontrados. Use las opciones de REPAIR_*
solo como último recurso. La base de datos especificada debe estar en modo de usuario único para utilizar una de las siguientes opciones de reparación.
REPAIR_ALLOW_DATA_LOSS
Intenta reparar todos los errores indicados. Estas reparaciones pueden ocasionar alguna pérdida de datos.
Advertencia
La opción
REPAIR_ALLOW_DATA_LOSS
puede provocar más pérdida de datos que si restaura desde una última copia de seguridad correcta conocida. Consulte Advertencia de pérdida de datos con REPAIR_ALLOW_DATA_LOSSMicrosoft siempre recomienda que el usuario haga una restauración de la última copia de seguridad correcta como método principal para corregir los errores notificados por
DBCC CHECKDB
. La opciónREPAIR_ALLOW_DATA_LOSS
no es una alternativa para restaurar a partir de una copia de seguridad buena. Se trata de una opción de último recurso recomendada para su uso solo si no es posible restaurar desde una copia de seguridad.Algunos errores, que solo se pueden reparar mediante la opción
REPAIR_ALLOW_DATA_LOSS
, pueden implicar desasignar una fila, página o serie de páginas para borrar los errores. Los datos desasignados ya no son accesibles ni recuperables para el usuario y no se puede determinar el contenido exacto de los datos desasignados. Por lo tanto, es posible que la integridad referencial no sea precisa después de desasignar filas o páginas porque las restricciones de clave externa no se comprueban ni se mantienen como parte de esta operación de reparación. El usuario debe inspeccionar la integridad referencial de su base de datos (medianteDBCC CHECKCONSTRAINTS
) después de usar la opciónREPAIR_ALLOW_DATA_LOSS
.Antes de realizar la reparación, debe crear copias físicas de los archivos que pertenezcan a esta base de datos. Esto incluye el archivo de datos principal (
.mdf
), los archivos de datos secundarios (.ndf
), todos los archivos de registro de transacciones (.ldf
) y otros contenedores que forman la base de datos como catálogos de texto completo, carpetas de secuencia de archivos, datos optimizados en memoria, etc.Antes de realizar la reparación, plantéese cambiar el estado de la base de datos al modo
EMERGENCY
, intente extraer tanta información como sea posible de las tablas críticas y guarde esos datos.REPAIR_FAST
La sintaxis se mantiene únicamente por compatibilidad con versiones anteriores. No se realizan acciones de reparación.
REPAIR_REBUILD
Realiza reparaciones que no tienen ninguna posibilidad de pérdida de datos. Esta opción puede incluir reparaciones rápidas, como la reparación de filas que faltan en índices no clúster y más reparaciones que consumen mucho tiempo, como volver a generar un índice.
Este argumento no repara errores relacionados con datos de FILESTREAM.
Importante
Dado que DBCC CHECKDB
con cualquiera de las opciones de REPAIR_*
se registran y recuperan por completo, Microsoft recomienda siempre que un usuario use DBCC CHECKDB
con las opciones de REPAIR_*
dentro de una transacción (ejecute BEGIN TRANSACTION
antes de ejecutar el comando) para que el usuario pueda confirmar que desea aceptar los resultados de la operación. Después, el usuario puede ejecutar COMMIT TRANSACTION
para confirmar todo el trabajo realizado por la operación de reparación. Si el usuario no quiere aceptar los resultados de la operación, puede ejecutar un ROLLBACK TRANSACTION
para deshacer los efectos de las operaciones de reparación.
Para reparar errores, se recomienda restaurar a partir de una copia de seguridad. Las operaciones de reparación no tienen en cuenta ninguna de las restricciones que pueden existir en las tablas o entre ellas. Si la tabla especificada está implicada en una o más restricciones, se recomienda ejecutar DBCC CHECKCONSTRAINTS
tras una operación de reparación. Si debe usar REPAIR_*
, ejecute DBCC CHECKDB
sin la opción de reparación para determinar el nivel de reparación que debe emplearse. Si se va a usar el nivel REPAIR_ALLOW_DATA_LOSS
, se recomienda realizar una copia de seguridad de la base de datos antes de ejecutar DBCC CHECKDB
con esta opción.
ALL_ERRORMSGS
Muestra todos los errores notificados por objeto. De forma predeterminada, se muestran todos los mensajes de error. Especificar u omitir esta opción no tiene ningún efecto. Los mensajes de error se ordenan por identificador de objeto, salvo en el caso de los mensajes generados desde la base de datos tempdb.
EXTENDED_LOGICAL_CHECKS
Si el nivel de compatibilidad es 100, introducido en SQL Server 2008 (10.0.x), esta opción realiza comprobaciones de coherencia lógica en una vista indexada, en índices XML y en índices espaciales, en caso de que los haya.
Para más información, consulte Realización de comprobaciones de coherencia lógica en índices más adelante en este artículo.
NO_INFOMSGS
Suprime todos los mensajes de información.
TABLOCK
Hace que DBCC CHECKDB
obtenga bloqueos en lugar de usar una instantánea de base de datos interna. Se incluye un bloqueo exclusivo (X) a corto plazo en la base de datos. TABLOCK
hace que DBCC CHECKDB
se ejecuten más rápido en una base de datos con mucha carga, pero disminuye la simultaneidad disponible en la base de datos mientras se ejecuta DBCC CHECKDB
.
Importante
TABLOCK
limita las comprobaciones que se realizan; DBCC CHECKCATALOG
no se ejecuta en la base de datos y no se validan los datos de Service Broker.
ESTIMATEONLY
Muestra la cantidad de espacio tempdb
para la base de datos que se estima necesario para ejecutar DBCC CHECKDB
con todas las demás opciones especificadas. No se realiza la comprobación real de la base de datos.
PHYSICAL_ONLY
Limita la comprobación a la integridad de la estructura física de los encabezados de página y registro y la coherencia de la asignación de la base de datos. Esta comprobación se ha diseñado para proporcionar una pequeña comprobación de sobrecarga de la coherencia física de la base de datos; también detecta páginas rasgadas, errores de suma de comprobación y errores de hardware comunes que pueden comprometer los datos del usuario.
Una ejecución completa de DBCC CHECKDB
puede tardar considerablemente más tiempo en completarse que las versiones anteriores. Este comportamiento se produce porque:
- Las comprobaciones lógicas son más exhaustivas.
- Algunas de las estructuras subyacentes que hay que comprobar son más complejas.
- Se han agregado muchas comprobaciones nuevas para incluir las nuevas características.
Por lo tanto, el uso de la opción PHYSICAL_ONLY
puede provocar un tiempo de ejecución mucho menor para DBCC CHECKDB
en bases de datos de gran tamaño y se recomienda para su uso frecuente en los sistemas de producción. Aun así, se recomienda realizar una ejecución completa de DBCC CHECKDB
periódicamente. La frecuencia de estas ejecuciones depende de factores específicos de cada empresa y de los entornos de producción.
Este argumento siempre implica NO_INFOMSGS
y no se permite con ninguna de las opciones de reparación.
Advertencia
La especificación de PHYSICAL_ONLY
provoca que DBCC CHECKDB
omita todas las comprobaciones de los datos FILESTREAM.
DATA_PURITY
Hace que DBCC CHECKDB
compruebe si la base de datos contiene valores de columna que no son válidos o están fuera del intervalo correcto. Por ejemplo, DBCC CHECKDB
detecta las columnas cuyos valores de fecha y hora son superiores o inferiores al intervalo de valores válido para el tipo de datos datetime, o bien las columnas del tipo de datos decimal o numérico aproximado con valores de escala o precisión que no son válidos.
Las comprobaciones de integridad de valores de columna están habilitadas de manera predeterminada y no requieren la opción DATA_PURITY
. De manera predeterminada, en las bases de datos actualizadas desde versiones anteriores de SQL Server, las comprobaciones de valores de columna no se habilitan hasta que no se ejecuta DBCC CHECKDB WITH DATA_PURITY
sin errores en la base de datos. Después, DBCC CHECKDB
comprueba la integridad de los valores de columna de manera predeterminada. Para obtener más información sobre cómo la actualización de bases de datos de versiones anteriores de SQL Server podría afectar a CHECKDB
, vea la sección Comentarios más adelante en este artículo.
Advertencia
Si se especifica PHYSICAL_ONLY
, no se realizan comprobaciones de integridad de columna.
Los errores de validación de los que informe esta opción no se pueden corregir con las opciones de reparación de DBCC. Para obtener información sobre cómo corregir manualmente estos errores, consulte MSSQLSERVER_2570.
MAXDOP
Se aplica a: SQL Server 2014 (12.x) Service Pack 2 y versiones posteriores
Invalida la opción de configuración max degree of parallelism
de sp_configure
para la instrucción. MAXDOP
puede superar el valor configurado con sp_configure
. Si MAXDOP
supera el valor configurado con Resource Governor, el motor de base de datos de SQL Server usa el valor MAXDOP
de Resource Governor, descrito en ALTER WORKLOAD GROUP (Transact-SQL). Todas las reglas semánticas que se usan con la opción de configuración max degree of parallelism
son aplicables cuando se usa la sugerencia de consulta MAXDOP
. Para obtener más información, vea Configuración del servidor: grado máximo de paralelismo.
Advertencia
Si MAXDOP
se establece en cero, SQL Server elige el max degree of parallelism
que se va a usar.
Comentarios
DBCC CHECKDB
no examina los índices deshabilitados. Para obtener más información sobre los índices desactivados, vea Desactivar índices y restricciones.
Si un tipo definido por el usuario se marca como ordenado por bytes, solo debe existir una serialización del tipo definido por el usuario. La serialización incoherente de los tipos definidos por el usuario ordenados por bytes provoca el error 2537 cuando se ejecuta DBCC CHECKDB
. Para obtener más información, consulte Crear tipos definidos por el usuario: requisitos.
Dado que solo se puede modificar la base de datos Resource en modo de usuario único, el comando DBCC CHECKDB
no se puede ejecutar directamente en ella. Aun así, al ejecutar DBCC CHECKDB
en la base de datos maestra, se ejecuta un segundo comando CHECKDB
internamente en la base de datos Resource. Esto significa que DBCC CHECKDB
puede devolver resultados adicionales. El comando devuelve conjuntos de resultados adicionales cuando no se establecen opciones o cuando se establecen las opciones PHYSICAL_ONLY
o ESTIMATEONLY
.
En SQL Server 2005 (9.x) Service Pack 2 y versiones posteriores, la ejecución de DBCC CHECKDB
deja de borrar la caché de planes para la instancia de SQL Server. En versiones anteriores a SQL Server 2005 (9.x) Service Pack 2, ejecutar DBCC CHECKDB
borra la caché del plan. Borrar la caché del plan provoca la recompilación de todos los planes de ejecución posteriores y puede provocar una disminución repentina y temporal del rendimiento de las consultas.
Realización de comprobaciones de coherencia lógica en índices
La comprobación de coherencia lógica en índices varía según el nivel de compatibilidad de la base de datos, tal como se indica a continuación:
Si el nivel de compatibilidad es de al menos 100 (introducido en SQL Server 2008 [10.0.x]):
A menos que se especifique
NOINDEX
,DBCC CHECKDB
realiza comprobaciones de coherencia física y lógica en una sola tabla y en todos sus índices no agrupados. Sin embargo, en los índices XML, índices espaciales y vistas indizadas solo se realizan comprobaciones de coherencia física de forma predeterminada.Si se especifica
WITH EXTENDED_LOGICAL_CHECKS
, se realizan comprobaciones lógicas en una vista indexada, índices XML e índices espaciales, si los hay. De forma predeterminada, las comprobaciones de coherencia física se realizan antes que las comprobaciones de coherencia lógica. Si también se especificaNOINDEX
, solamente se realizarán las comprobaciones lógicas.
Estas comprobaciones de coherencia lógica comprueban la tabla de índice interna del objeto de índice con la tabla de usuario a la que hace referencia. Para buscar las filas periféricas, se crea una consulta interna que lleve a cabo una intersección completa de las tablas internas y del usuario. La ejecución de esta consulta puede afectar de manera significativa al rendimiento y no se puede realizar el seguimiento de su progreso. Por consiguiente, se recomienda especificar únicamente WITH EXTENDED_LOGICAL_CHECKS
si cree que existen problemas del índice que no estén relacionados con daños físicos, o si las sumas de comprobación del nivel de página se han desactivado y sospecha que puedan existir daños de hardware de nivel de columna.
Si el índice es un índice filtrado,
DBCC CHECKDB
realizará las comprobaciones de coherencia para comprobar que las entradas de índice satisfacen el predicado de filtro.Si el nivel de compatibilidad es 90 o menos, a menos que se especifique
NOINDEX
,DBCC CHECKDB
realiza las comprobaciones de coherencia física y lógica en una tabla única o vista indexada y en todos sus índices XML e índices no clúster. Los índices espaciales no se admiten.En SQL Server 2016 (13.x) y versiones posteriores, las comprobaciones adicionales de las columnas calculadas persistentes, las columnas UDT y los índices filtrados no se ejecutan de forma predeterminada para evitar las evaluaciones de expresiones costosas. Este cambio reduce considerablemente la duración de
CHECKDB
en bases de datos que contienen estos objetos. A pesar de ello, las comprobaciones de coherencia física de estos objetos siempre se completan. Solo cuando se especifica la opciónEXTENDED_LOGICAL_CHECKS
, se realizan las evaluaciones de expresiones, además de las comprobaciones lógicas que ya están presentes como parte de la opciónEXTENDED_LOGICAL_CHECKS
(vista indexada, índices XML e índices espaciales).
Obtenga información sobre el nivel de compatibilidad de una base de datos.
Instantánea de base de datos interna
DBCC CHECKDB
usa una instantánea de la base de datos interna para la coherencia transaccional necesaria para realizar estas comprobaciones. Así se evitan problemas de bloqueo y simultaneidad cuando se ejecutan estos comandos. Para obtener más información, consulte Ver el tamaño del archivo disperso de una instantánea de base de datos y la sección Uso de instantáneas de base de datos internas de DBCC en DBCC. Si no se puede crear una instantánea o se especifica TABLOCK
, DBCC CHECKDB
adquiere bloqueos para obtener la coherencia necesaria. En este caso, se requiere un bloqueo exclusivo de base de datos para realizar las comprobaciones de asignación y se requieren bloqueos compartidos de tabla para realizar las comprobaciones de tabla.
DBCC CHECKDB
produce un error cuando se ejecuta contra la base de datos master
si no se puede crear una instantánea de base de datos interna.
Al ejecutar DBCC CHECKDB
en tempdb
, no se realiza ninguna comprobación de asignación ni de catálogos, y se deben adquirir bloqueos de uso compartido de las tablas para realizar las comprobaciones de tabla. Esto es debido a que por motivos de rendimiento las instantáneas de base de datos no están disponibles en tempdb
. Eso significa que no es posible obtener la coherencia transaccional necesaria.
Cómo crea DBCC CHECKDB una base de datos de instantáneas interna a partir SQL Server 2014
DBCC CHECKDB
crea una base de datos de instantáneas interna.La base de datos de instantáneas interna se crea mediante archivos físicos. Por ejemplo, para una base de datos con
database_id = 10
que tiene tres archivosE:\Data\my_DB.mdf
,E:\Data\my_DB.ndf
yE:\Data\my_DB.ldf
, la base de datos de instantáneas interna se crea mediante archivosE:\Data\my_DB.mdf_MSSQL_DBCC11
yE:\Data\my_DB.ndf_MSSQL_DBCC11
. El identificadordatabase_id
de la instantánea esdatabase_id + 1
. Tenga en cuenta también que los nuevos archivos se crean en la misma carpeta mediante la convención de nomenclatura<filename.extension>_MSSQL_DBCC<database_id_of_snapshot>
. No se crea ningún archivo disperso para el registro de transacciones.Los nuevos archivos se marcan como archivos dispersos en el nivel del sistema de archivos. El tamaño en disco usado por los nuevos archivos aumenta en función de la cantidad de datos que se actualizan en la base de datos de origen durante el comando
DBCC CHECKDB
. El Tamaño de los nuevos archivos es el mismo que el archivo.mdf
o.ndf
.Los nuevos archivos se eliminan al final del procesamiento de
DBCC CHECKDB
. Estos archivos dispersos creados porDBCC CHECKDB
tienen establecidos los atributos "Delete on Close (Eliminar al cerrar)".
Advertencia
Si el sistema operativo encuentra un apagado inesperado mientras el comando DBCC CHECKDB
está en curso, estos archivos no se limpian. Ocupan espacio y pueden provocar errores en futuras ejecuciones de DBCC CHECKDB
. En ese caso, puede eliminar estos nuevos archivos después de confirmar que no hay ningún comando DBCC CHECKDB
que se esté ejecutando actualmente.
Los nuevos archivos son visibles mediante utilidades de archivos normales, como Explorador de Windows.
Nota
En versiones anteriores a SQL Server 2014 (12.x), se usaron secuencias de archivos con nombre en su lugar para crear los archivos de instantáneas internos. Los flujos de archivo con nombre usan el formato <filename.extension>:MSSQL_DBCC<database_id_of_snapshot>. Los flujos de archivos con nombre no son visibles mediante utilidades de archivos normales como el Explorador de Windows. Por lo tanto, en SQL Server 2012 (11.x) y versiones anteriores, es posible que encuentre mensajes de error 7926 y 5030 al ejecutar el comando
Comprobación y reparación de datos FILESTREAM
Cuando FILESTREAM está habilitado para una base de datos y una tabla, puede almacenar opcionalmente los objetos binarios grandes (BLOB) varbinary(max) en el sistema de archivos. Al usar DBCC CHECKDB
en una base de datos que almacena BLOB en el sistema de archivos, DBCC comprueba la coherencia de nivel de vínculo entre el sistema de archivos y la base de datos.
Por ejemplo, si una tabla contiene una columna varbinary(max) que usa el atributo FILESTREAM, DBCC CHECKDB
comprueba que existe una correspondencia uno a uno entre los directorios del sistema de archivos y los archivos, y las filas de la tabla, columnas y valores de las columnas. DBCC CHECKDB
puede reparar la corrupción si especifica la opción REPAIR_ALLOW_DATA_LOSS
. Para reparar la corrupción de FILESTREAM, DBCC elimina las filas de tabla que no tienen datos correspondientes en el sistema de archivos.
Procedimientos recomendados
Se recomienda utilizar la opción PHYSICAL_ONLY
si se usa con frecuencia en sistemas de producción. El uso de PHYSICAL_ONLY
puede disminuir considerablemente el tiempo de ejecución para DBCC CHECKDB
en base de datos grandes. También se recomienda ejecutar DBCC CHECKDB
sin opciones de forma periódica. La frecuencia con que se deben realizar estas ejecuciones varía en función de la empresa y su entorno de producción.
En Azure SQL Instancia administrada, el espacio de almacenamiento disponible debe adaptarse a todo el archivo de instantáneas de base de datos interno creado por DBCC CHECKDB
, independientemente de la cantidad de datos que realmente use. Esto puede provocar una situación en la que se DBCC CHECKDB
ejecuta en una base de datos muy grande pero dispersa (el tamaño de los datos es mucho menor que el tamaño del archivo de base de datos) produce un error debido a la falta de espacio en la instancia administrada de SQL. Si DBCC CHECKDB
consume todo el espacio de almacenamiento disponible durante la ejecución, recibirá el siguiente mensaje de error:
Msg 1133, Level 16, State 3, Line 1
The managed instance has reached its storage limit. To storage usage for the managed instance cannot exceed (...) MBs.
You might need to temporarily scale up your SQL managed instance storage capacity before running `DBCC CHECKDB` again.
Comprobación de objetos en paralelo
De forma predeterminada, DBCC CHECKDB
realiza comprobaciones paralelas de los objetos. El grado de paralelismo se determina automáticamente mediante el procesador de consultas. El grado máximo de paralelismo se configura igual que las consultas paralelas. Para restringir el número máximo de procesadores disponibles para las comprobaciones DBCC, use sp_configure. Para obtener más información, vea Configuración del servidor: grado máximo de paralelismo. La comprobación del paralelismo se puede deshabilitar con el marcador de seguimiento 2528. Para obtener más información, vea Marcas de seguimiento.
Nota
Esta característica no está disponible en todas las ediciones de SQL Server. Para más información, consulte la comprobación de coherencia paralela en la sección Capacidad de administración de RDBMS de Ediciones y características admitidas de SQL Server 2022.
Descripción de los mensajes de error de DBCC
Cuando el comando DBCC CHECKDB
finaliza, se escribe un mensaje en el registro de errores de SQL Server. Si el comando DBCC se ejecuta correctamente, el mensaje lo indica, así como el tiempo de ejecución del comando. Si el comando DBCC se detiene antes de finalizar la comprobación debido a un error, el mensaje indica que el comando se ha cancelado, un valor de estado y el tiempo de ejecución del comando. En la tabla siguiente se muestran y describen los valores de estado que pueden aparecer en el mensaje.
State | Descripción |
---|---|
0 |
Se ha generado el error número 8930. Esto indica que se interrumpió la ejecución del comando DBCC a causa de daños en los metadatos. |
1 |
Se ha generado el error número 8967. Error DBCC interno. |
2 |
Error durante una reparación de base de datos en modo de emergencia. |
3 |
Esto indica que se interrumpió la ejecución del comando DBCC a causa de daños en los metadatos. |
4 |
Se ha detectado una infracción de acceso o aserción. |
5 |
Error desconocido que cancela el comando DBCC. |
SQL Server registra la fecha y hora en que se ha ejecutado una comprobación de coherencia para una base de datos sin errores (o "limpia"). Esto se conoce como last known clean check
. Cuando se inicia una base de datos por primera vez, esta fecha se escribe en el registro de eventos (EventID-17573) y en el registro de errores en el formato siguiente:
CHECKDB for database '<database>' finished without errors on 2022-05-05 18:08:22.803 (local time). This is an informational message only; no user action is required.
Informe de errores
Se crea un volcado de pila (SQLDump<nnnn>.txt
, SQLDump<nnnn>.log
, SQLDump<nnnn>.mdmp
) en el directorio LOG
de SQL Server cada vez que DBCC CHECKDB
detecta un error de corrupción. Si las características de recopilación de datos de Uso de la característica e Informes de errores están habilitadas para la instancia de SQL Server, el archivo se reenvía automáticamente a Microsoft. Los datos recopilados se utilizan para mejorar la funcionalidad de SQL Server.
El archivo de volcado contiene los resultados del comando DBCC CHECKDB
y los resultados del diagnóstico adicional. El acceso está limitado a la cuenta de servicio de SQL Server y a los miembros del rol sysadmin. De forma predeterminada, el rol sysadmin contiene todos los miembros del grupo BUILTIN\Administrators
de Windows y el grupo de administradores local. El comando DBCC no producirá error en caso de que se produzca un error en el proceso de recopilación de datos.
Resolución de errores
Si DBCC CHECKDB
notifica algún error, se recomienda restaurar la base de datos a partir de la copia de seguridad de la base de datos, en lugar de ejecutar DBCC CHECKDB
con una de las opciones de REPAIR_*
. Si no hay ninguna copia de seguridad, al ejecutar REPAIR se corrigen los errores notificados. La opción de reparación que se debe utilizar se especifica al final de la lista de errores notificados. No obstante, la corrección de errores mediante la opción REPAIR_ALLOW_DATA_LOSS
puede requerir eliminar algunas páginas y, por tanto, también algunos datos.
En algunas circunstancias, es posible que la base de datos contenga valores que no son válidos o que no están comprendidos en el intervalo correcto de acuerdo con el tipo de datos de la columna. DBCC CHECKDB
puede detectar valores de columna que no son válidos para todos los tipos de datos de columna. Por tanto, al ejecutar DBCC CHECKDB
con la opción DATA_PURITY
en bases de datos que se han actualizado desde versiones anteriores de SQL Server, pueden desvelarse errores de valores de columna que ya existían. Dado que SQL Server no puede reparar estos errores de forma automática, será necesario actualizar el valor de la columna de forma manual. Si CHECKDB
detecta un error de este tipo, CHECKDB
devuelve una advertencia, el número de error 2570 e información para identificar la fila afectada y corregir el error manualmente.
La reparación se puede realizar en una transacción de usuario para permitirle revertir los cambios realizados. Si se revierten las reparaciones, la base de datos todavía contiene errores y se debe restaurar a partir de una copia de seguridad. Una vez finalizadas las reparaciones, realice una copia de seguridad de la base de datos.
Resolución de errores en modo de emergencia de base de datos
Cuando se establece una base de datos en modo de emergencia mediante la instrucción ALTER DATABASE, DBCC CHECKDB
puede realizar algunas reparaciones especiales en la base de datos si se especifica la opción REPAIR_ALLOW_DATA_LOSS
. Estas reparaciones pueden permitir que las bases de datos normalmente irrecuperables se devuelvan en línea en un estado físicamente coherente. Estas reparaciones solo deben usarse como último recurso y solo cuando no se puede restaurar la base de datos a partir de una copia de seguridad. Cuando la base de datos se establece en modo de emergencia, se marca como READ_ONLY, el registro está deshabilitado y el acceso se limita a los miembros del rol fijo de servidor sysadmin.
Nota
No puede ejecutar el comando DBCC CHECKDB
en modo de emergencia dentro de una transacción de usuario y revertir la transacción después de la ejecución.
Cuando la base de datos está en modo de emergencia y se ejecuta DBCC CHECKDB
con la cláusula REPAIR_ALLOW_DATA_LOSS
, se realizan las siguientes acciones:
DBCC CHECKDB
usa páginas marcadas como inaccesibles debido a errores de suma de comprobación o de E/S como si los errores no se hubieran producido. De esta manera aumentan las posibilidades de recuperación de datos de la base de datos.DBCC CHECKDB
intenta recuperar la base de datos mediante las técnicas habituales de recuperación basadas en el registro.Si la recuperación de la base de datos no puede realizarse debido a daños en el registro de transacciones, dicho registro de transacciones volverá a generarse. Volver a generar el registro de transacciones puede dar lugar a la pérdida de coherencia transaccional.
Advertencia
La opción REPAIR_ALLOW_DATA_LOSS
puede provocar más pérdida de datos que si restaura desde una última copia de seguridad correcta conocida. Consulte Advertencia de pérdida de datos con REPAIR_ALLOW_DATA_LOSS
Si el comando DBCC CHECKDB
se ejecuta correctamente, la base de datos está en un estado físicamente coherente y se establece su estado en ONLINE. Sin embargo, la base de datos puede contener una o varias incoherencias transaccionales. Es recomendable ejecutar DBCC CHECKCONSTRAINTS para identificar defectos de la lógica de negocios y realizar inmediatamente una copia de seguridad de la base de datos.
Si el comando DBCC CHECKDB
produce un error, la base de datos no se puede reparar.
Advertencia de pérdida de datos con REPAIR_ALLOW_DATA_LOSS
La opción REPAIR_ALLOW_DATA_LOSS
es una característica compatible con SQL Server. Sin embargo, es posible que no siempre sea la mejor opción para llevar una base de datos a un estado físicamente coherente. Si se ejecuta correctamente, la opción REPAIR_ALLOW_DATA_LOSS
puede dar lugar a una pérdida de datos.
De hecho, puede dar lugar a que se pierdan más datos que si un usuario restaurara la base de datos a partir de la última copia de seguridad correcta conocida. Microsoft siempre recomienda que el usuario haga una restauración de la última copia de seguridad correcta como método principal para corregir los errores notificados por DBCC CHECKDB
.
La opción REPAIR_ALLOW_DATA_LOSS
no es una alternativa para restaurar a partir de una copia de seguridad buena. Es una opción de emergencia como último recurso que solo le recomendamos usar si no es posible restaurar a partir de una copia de seguridad.
Después de reconstruir el registro, no hay ninguna garantía completa ACID.
Después de recompilar el registro, DBCC CHECKDB
se lleva a cabo automáticamente e informa y corrige los problemas de coherencia física.
Las restricciones reguladas por la lógica empresarial y por la coherencia de datos lógicos se deben validar manualmente.
El tamaño del registro de transacciones se deja a su tamaño predeterminado y se debe ajustar manualmente a su tamaño reciente.
Ejecución de DBCC CHECKDB con REPAIR_ALLOW_DATA_LOSS en bases de datos replicadas
La ejecución del comando DBCC CHECKDB
con la opción REPAIR_ALLOW_DATA_LOSS
puede afectar a las bases de datos de usuario (bases de datos de publicaciones y suscripciones) y a la base de datos de distribución que usa la replicación. Las bases de datos de publicaciones y suscripciones incluyen tablas publicadas y tablas de metadatos de replicación. Debe tener en cuenta los siguientes problemas potenciales en estas bases de datos:
Tablas publicadas. Puede que no se repliquen las acciones realizadas por el proceso
CHECKDB
para reparar datos de usuario dañados:La replicación de mezcla utiliza desencadenadores para realizar el seguimiento de los cambios en tablas publicadas. Si el proceso
CHECKDB
inserta, actualiza o elimina filas, no se activan los desencadenadores, por lo que el cambio no se replica.La replicación transaccional utiliza el registro de transacciones para realizar el seguimiento de los cambios en tablas publicadas. Posteriormente, el Agente de registro del LOG mueve estos cambios a la base de datos de distribución. Es posible que el Agente de registro del LOG no pueda replicar algunas reparaciones de DBCC, aunque se hayan registrado. Por ejemplo, si el proceso
CHECKDB
cancela la asignación de una página de datos, el Agente de registro del LOG no convierte esta desasignación en una instrucción DELETE; por tanto, el cambio no se replica.Tablas de metadatos de replicación. Las acciones que realiza el proceso
CHECKDB
para reparar tablas de metadatos de replicación dañadas requieren que se quite y se vuelva a configurar la replicación.
Si debe ejecutar el comando DBCC CHECKDB
con la opción REPAIR_ALLOW_DATA_LOSS
en una base de datos de usuario o en una base de datos de distribución:
Ponga el sistema en modo inactivo: Detenga la actividad en la base de datos y en todas las demás bases de datos de la topología de replicación e intente sincronizar todos los nodos. Para más información, vea Poner en modo inactivo una topología de replicación (programación de la replicación con Transact-SQL).
Ejecute
DBCC CHECKDB
.Si el informe de
DBCC CHECKDB
incluye reparaciones de tablas de la base de datos de distribución o de tablas de metadatos de replicación en una base de datos de distribución, quite la replicación y vuelva a configurarla. Para obtener más información, vea Deshabilitar la publicación y distribución.Si el informe de
DBCC CHECKDB
incluye reparaciones de tablas replicadas, lleve a cabo la validación de datos para determinar dónde se encuentran las diferencias entre los datos de las bases de datos de publicaciones y de suscripciones.
Conjunto de resultados
DBCC CHECKDB
devuelve el siguiente conjunto de resultados. Los valores pueden variar excepto cuando se especifican las opciones de ESTIMATEONLY
, PHYSICAL_ONLY
o NO_INFOMSGS
:
DBCC results for 'model'.
Service Broker Msg 9675, Level 10, State 1: Message Types analyzed: 13.
Service Broker Msg 9676, Level 10, State 1: Service Contracts analyzed: 5.
Service Broker Msg 9667, Level 10, State 1: Services analyzed: 3.
Service Broker Msg 9668, Level 10, State 1: Service Queues analyzed: 3.
Service Broker Msg 9669, Level 10, State 1: Conversation Endpoints analyzed: 0.
Service Broker Msg 9674, Level 10, State 1: Conversation Groups analyzed: 0.
Service Broker Msg 9670, Level 10, State 1: Remote Service Bindings analyzed: 0.
DBCC results for 'sys.sysrowsetcolumns'.
There are 630 rows in 7 pages for object 'sys.sysrowsetcolumns'.
DBCC results for 'sys.sysrowsets'.
There are 97 rows in 1 pages for object 'sys.sysrowsets'.
DBCC results for 'sysallocunits'.
There are 195 rows in 3 pages for object 'sysallocunits'.
There are 0 rows in 0 pages for object "sys.sysasymkeys".
DBCC results for 'sys.syssqlguides'.
There are 0 rows in 0 pages for object "sys.syssqlguides".
DBCC results for 'sys.queue_messages_1977058079'.
There are 0 rows in 0 pages for object "sys.queue_messages_1977058079".
DBCC results for 'sys.queue_messages_2009058193'.
There are 0 rows in 0 pages for object "sys.queue_messages_2009058193".
DBCC results for 'sys.queue_messages_2041058307'.
There are 0 rows in 0 pages for object "sys.queue_messages_2041058307".
CHECKDB found 0 allocation errors and 0 consistency errors in database 'model'.
DBCC execution completed. If DBCC printed error messages, contact your system administrator.
DBCC CHECKDB
devuelve el siguiente conjunto de resultados (mensaje) cuando se especifica NO_INFOMSGS
:
The command(s) completed successfully.
DBCC CHECKDB
devuelve el siguiente conjunto de resultados cuando se especifica PHYSICAL_ONLY
:
DBCC results for 'model'.
CHECKDB found 0 allocation errors and 0 consistency errors in database 'master'.
DBCC execution completed. If DBCC printed error messages, contact your system administrator.
DBCC CHECKDB
devuelve el siguiente conjunto de resultados cuando se especifica ESTIMATEONLY
.
Estimated TEMPDB space needed for CHECKALLOC (KB)
-------------------------------------------------
13
(1 row(s) affected)
Estimated TEMPDB space needed for CHECKTABLES (KB)
--------------------------------------------------
57
(1 row(s) affected)
DBCC execution completed. If DBCC printed error messages, contact your system administrator.
Permisos
Requiere la pertenencia al rol fijo de servidor sysadmin o al rol fijo de base de datos db_owner.
Ejemplos
A. Comprobación de la base de datos actual y otra base de datos
En el ejemplo siguiente se ejecuta DBCC CHECKDB
para la base de datos actual y para la base de datos AdventureWorks2022
.
-- Check the current database.
DBCC CHECKDB;
GO
-- Check the AdventureWorks2022 database without nonclustered indexes.
DBCC CHECKDB (AdventureWorks2022, NOINDEX);
GO
B. Comprobación de la base de datos actual, suprimiendo los mensajes informativos
En el ejemplo siguiente se comprueba la base de datos actual y se suprimen todos los mensajes informativos.
DBCC CHECKDB WITH NO_INFOMSGS;
GO