DBCC CHECKCONSTRAINTS (Transact-SQL)

适用于:SQL ServerAzure SQL 数据库Azure SQL 托管实例

检查当前数据库中指定表上的指定约束或所有约束的完整性。

Transact-SQL 语法约定

语法

DBCC CHECKCONSTRAINTS
[
    (
    table_name | table_id | constraint_name | constraint_id
    )
]
    [ WITH
    [ { ALL_CONSTRAINTS | ALL_ERRORMSGS } ]
    [ , ] [ NO_INFOMSGS ]
    ]

参数

table_nametable_id | constraint_nameconstraint_id

要检查的表或约束。 如果指定了 table_name 或 table_id,将对该表中所有启用的约束进行检查 。 如果指定了 constraint_name 或 constraint_id,则仅检查该约束 。 如果未指定表标识符或约束标识符,则对当前数据库中所有表上的已启用约束进行检查。

约束名称唯一地标识其所属于的表。 有关详细信息,请参阅 Database Identifiers

WITH

启用要指定的选项。

  • ALL_CONSTRAINTS

    如果指定了表名或检查所有的表,则对表上所有启用及禁用的约束进行检查;否则,仅对启用的约束进行检查。 如果指定了约束名,则 ALL_CONSTRAINTS 无效。

  • ALL_ERRORMSGS

    返回所检查的表中违反约束的所有行。 默认为前 200 行。

  • NO_INFOMSGS

    取消显示所有信息性消息。

备注

DBCC CHECKCONSTRAINTS 构造并执行一个对表的所有 FOREIGN KEY 和 CHECK 约束的查询。

例如,外键查询可具有如下形式:

SELECT <columns>
FROM <table_being_checked> LEFT JOIN <referenced_table>
    ON <table_being_checked.fkey1> = <referenced_table.pkey1>
    AND <table_being_checked.fkey2> = <referenced_table.pkey2>
WHERE <table_being_checked.fkey1> IS NOT NULL
    AND <referenced_table.pkey1> IS NULL
    AND <table_being_checked.fkey2> IS NOT NULL
    AND <referenced_table.pkey2> IS NULL;

查询数据存储在临时表中。 检查完所有请求的表和约束后,将返回结果集。

DBCC CHECKCONSTRAINTS 检查 FOREIGN KEY 和 CHECK 约束的完整性,但并不检查表的磁盘上数据结构的完整性。 可使用 DBCC CHECKDBDBCC CHECKTABLE 执行这些数据结构检查。

适用于:SQL Server 2016 (13.x) 及更高版本

如果已指定 table_name 或 table_id 并启用它用于系统版本控制,则 还会对指定表执行临时数据一致性检查。 如果未指定 NO_INFOMSGS,此命令将在单独一行上在输出中返回每项一致性冲突。 输出的格式将为 ([pkcol1], [pkcol2]..) = (<pkcol1_value>, <pkcol2_value>...) AND <what is wrong with temporal table record>

勾选标记 检查失败时输出中的其他信息
PeriodEndColumn >= PeriodStartColumn(当前) [sys_end] = '{0}' AND MAX(DATETIME2) = '9999-12-31 23:59:59:59.99999'
PeriodEndColumn >= PeriodStartColumn(当前、历史记录) [sys_start] = '{0}' AND [sys_end] = '{1}'
PeriodStartColumn < current_utc_time(当前) [sys_start] = '{0}' AND SYSUTCTIME
PeriodEndColumn < current_utc_time(历史记录) [sys_end] = '{0}' AND SYSUTCTIME
重叠 对于两个重叠记录,则为(sys_start1, sys_end1)、(sys_start2, sys_end2)。

如果有两个以上的重叠记录,输出也将具有多行,每行显示一对重叠。

无法指定 constraint_nameconstraint_id 来仅运行临时一致性检查。

结果集

DBCC CHECKCONSTRAINTS 返回带有以下列的行集。

列名称 数据类型 说明
表名称 varchar 表的名称。
约束名称 varchar 违反的约束名。
其中 varchar 标识违反约束的行的列值分配。

该列中的值可以用于 SELECT 语句(用于查询违反约束的行)的 WHERE 子句中。

DBCC CHECKCONSTRAINTS 不能保证找到所有约束冲突。 如果单个行违反多个约束,则仅列出第一个冲突的 WHERE 子句。 除非另一行存在可产生冲突的相同值组合,并将该冲突作为发现的第一个冲突,否则返回的结果集中将缺少值组合。 在查找数据库中的所有约束冲突之前,可能需要多次运行 DBCC CHECKCONSTRAINTS 和修复问题。

权限

要求具有 sysadmin 固定服务器角色或 db_owner 固定数据库角色的成员身份。

示例

A. 检查表

以下示例检查 Table1 数据库中的 AdventureWorks2022 表的约束完整性。

USE AdventureWorks2022;
GO
CREATE TABLE Table1 (Col1 INT, Col2 CHAR(30));
GO
INSERT INTO Table1 VALUES (100, 'Hello');
GO
ALTER TABLE Table1 WITH NOCHECK ADD CONSTRAINT chkTab1 CHECK (Col1 > 100);
GO
DBCC CHECKCONSTRAINTS (Table1);
GO

B. 检查特定约束

以下示例检查 CK_ProductCostHistory_EndDate 约束的完整性。

USE AdventureWorks2022;
GO
DBCC CHECKCONSTRAINTS ('Production.CK_ProductCostHistory_EndDate');
GO

C. 检查所有表的所有启用和禁用的约束

以下示例检查当前数据库中所有表上的所有启用和禁用约束的完整性。

DBCC CHECKCONSTRAINTS WITH ALL_CONSTRAINTS;
GO

另请参阅