这些脚本之间有什么区别?
ALTER TABLE Post_Send WITH NOCHECK CHECK CONSTRAINT [My_FOREIGN_KEY];
GO
ALTER TABLE Post_Send CHECK CONSTRAINT [My_FOREIGN_KEY];
GO发布于 2017-07-17 18:05:07
CHECK CONSTRAINT启用约束。(是的,它应该是ENABLE。) WITH NOCHECK这样做时不检查现有数据。因此,令人困惑的语法WITH NOCHECK CHECK CONSTRAINT在不检查现有数据的情况下启用了约束。
指定表中的数据是否根据新添加或重新启用的
FOREIGN KEY或CHECK约束进行验证。如果未指定,则对于新约束假定为WITH CHECK,对于重新启用的约束假定为WITH NOCHECK。
由于您正在重新启用现有的约束,因此WITH NOCHECK是默认的,并且这两个语句执行的是完全相同的事情。WITH CHECK CHECK CONSTRAINT将重新启用约束,同时检查现有数据是否存在违规(并将外键标记为可信,以便在流程中进行优化,如果您绕过检查,则不会发生这种情况)。
https://stackoverflow.com/questions/45140239
复制相似问题