SQLServer之修改CHECK约束

采用SSMS数据库管理工具修改CHECK约束

1、打开数据库,选择数据表-》右键点击-》选择设计(或者进行约束,选择约束,右键点击,选择修改,后面步骤同)。

图片 1

图片 2

2、选择而改的数码列-》右键点击-》选择CHECK约束。

图片 3

3、在CHECK约束弹出框中-》选择而改的约束-》输入约束表达式-》输入约束名和约束描述-》选择表设计器规则-》点击关闭。

图片 4

 4、点击保存按钮(或者ctrl+s)-》刷新表查看修改结果。

图片 5

行使T-SQL脚论修改CHECK约束

CHECK约束修改规则必须首先去现有的CHECK约,然后使用新定义再度创设,才会使用Transact-SQL修改CHECK约束。

语法:

–修改check约束
use 数据库名
go

–如果封锁是则先去
if exists(select * from sysobjects where
name=约束名)
alter table 表名 drop constraint
约束名;
go

–添加律
alter table 表名
–with check
–该约束是否使用被现有数量,with check表示用叫现有数据,with
nocheck代表未下为现有数量
add constraint 约束名
check
not for replication
–当复制代理于表中插入或更新数据常常,禁用该约束。
(约束表达式);
go

–为表中上加新数据要更新表中幸存数量时是否禁用该约束。check代表校验,nocheck表示不校验
–alter table 表名
–check
–constraint 表名;
–go

–添加check约束描述
execute sp_addextendedproperty
N’MS_Description’, N’约束描述’, N’SCHEMA’, N’dbo’, N’TABLE’, N’表名’,
N’CONSTRAINT’, N’约束名’;
go

示例:

–修改check约束
use testss
go

–如果封锁在则优先去
if exists(select * from sysobjects where
name=’u_check2′)
alter table test1 drop constraint
u_check2;
go

–添加约
alter table test1
–with check
–该约束是否采用叫现有数据,with check代表以为现有数量,with
nocheck表示不行使被现有数据
add constraint u_check2
check
not for replication
–当复制代理在表中插入或更新数据经常,禁用该约束。
(height>=100 and height
<=200);
go

–于表中上加新数据或者更新表中存活数量常常是否禁用该约束。check代表校验,nocheck表示不校验
–alter table test1
–check
–constraint u_check2;
–go

–添加check约束描述
execute sp_addextendedproperty
N’MS_Description’, N’修改约束’, N’SCHEMA’, N’dbo’, N’TABLE’, N’test1′,
N’CONSTRAINT’, N’u_check2′;
go

图片 6

图片 7

CHECK约束修改优缺点

优点:

1、修改数据库CHECK约束好保证数据的规范性和完整性。

缺点:

1:修改约束之表设计器使用规则时,可能会见滋生原有数据与约束之闯。

 

相关文章