我为我称为“等级”的列编写了以下约束:
CONSTRAINT gradeRule CHECK grade IN (‘easy’, ‘moderate’, ‘difficult’),
是否可以稍后更新gradeRule
以具有不同的值?例如,“中等”和“困难”可以更改为“中等”和“困难”。
谢谢
我为我称为“等级”的列编写了以下约束:
CONSTRAINT gradeRule CHECK grade IN (‘easy’, ‘moderate’, ‘difficult’),
是否可以稍后更新gradeRule
以具有不同的值?例如,“中等”和“困难”可以更改为“中等”和“困难”。
谢谢
您可以删除现有约束,并使用 NOCHECK 选项添加新约束。即使表中的数据违反了约束,这也允许您添加约束。这样做的问题在于,如果不先让它们通过约束,您将无法更新现有记录。
ALTER TABLE SomeTable DROP CONSTRAINT gradeRule
GO
ALTER TABLE SomeTable ADD CONSTRAINT gradeRule ... WITH NOCHECK
GO
尽管这是可能的,但通常不建议这样做,因为未来更新数据可能会出现问题。
删除约束,然后添加替换约束。您至少不能在 SQL Server 中更新约束。
ALTER TABLE SomeTable DROP CONSTRAINT gradeRule
此外,您需要在添加新约束之前更新表数据,使其符合新约束。
如果更改约束,则表中当前的所有数据都必须满足约束。因此,如果您有 2 行“中等”数据并尝试将约束更改为简单、中等和困难,它不会让您这样做。
因此,您必须设置新的约束(简单、中等、中等、困难、困难),或者将数据更新为新值 - 中等 --> 中等等。