SQL WITH NOCHECK 和 CLUSTERED | NONCLUSTERED

ALTER TABLE [dbo].[atr_cont_b] WITH NOCHECK ADD
 CONSTRAINT [PK_atr_cont_b] PRIMARY KEY  CLUSTERED
 (
  [id_cont_b]
 )  ON [PRIMARY]
GO

WITH NOCHECK:

 指定表中的数据是否用新添加的或重新启用的 FOREIGN KEY 或 CHECK 约束进行验证。如果没有指定,对于新约束,假定为 WITH CHECK,对于重新启用的约束,假定为 WITH NOCHECK。

我个人理解nocheck是针对已存在的数据而言的,也就是说我现在新增加或重新启用了一个约束,那么要不要对数据库中已存在的数据使用此

约束进行检查。nockeck就是不检查。

 

WITH CHECK | WITH NOCHECK
   指定表中的数据是否用新添加的或重新启用的 FOREIGN KEY 或 CHECK 约束进行验证。如果没有指定,对于新约束,假定为 WITH CHECK,对于重新启用的约束,假定为 WITH NOCHECK。


    还有CLUSTERED 是什么意思?是聚集索引的意思.
    CLUSTERED | NONCLUSTERED
    指定为 PRIMARY KEY 或 UNIQUE 约束创建聚集或非聚集索引。PRIMARY KEY 约束默认为 CLUSTERED;UNIQUE 约束默认为 NONCLUSTERED。

    如果表中已存在聚集约束或索引,那么在 ALTER TABLE 中就不能指定 CLUSTERED。如果表中已存在聚集约束或索引,PRIMARY KEY 约束默认为 NONCLUSTERED。

posted @ 2009-12-27 21:50  唔愛吃蘋果  阅读(1583)  评论(0编辑  收藏  举报