SQLServer之CHECK约束

SQLServer之CHECK约束

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

一 、打开数据库,选用数据表-》右键点击-》选取设计(或许拓展约束,接纳约束,右键点击,选拔修改,前面步骤一样)。

图片 1

图片 2

二 、选取要修改的数额列-》右键点击-》采取CHECK约束。

图片 3

3、在CHECK约束弹出框中-》选用要修改的自律-》输入约束表明式-》输入约束名和平条约束描述-》选拔表设计器规则-》点击关闭。

图片 4

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

图片 5

运用T-SQL脚本添加CHECK约束

当表结构已存在时

率先判断表中是不是留存暗中同意约束,假若存在则先删除暗中同意约束再添加,假使不设有则一直抬高。

语法:

use 数据库
go
–判断暗中同意约束是还是不是存在,假设存在则先删除,要是不设有则一向抬高
if exists(select * from sysobjects where
name=约束名)
alter table 表名 drop constraint
约束名;
go
–给钦点列添加默许约束
alter table 表名 add constraint 约束名
default(约束值) for 列名;
go

示例:

use [testss]
go
–判断暗许约束是不是存在,即使存在则先删除,借使不设有则一向抬高
if exists(select * from sysobjects where
name=’defalut_height’)
alter table [testss].[dbo].[test1]
drop constraint defalut_height;
go
–给指定列添加暗中认可约束
alter table [testss].[dbo].[test1]
add constraint defalut_height default(160) for height;
go

图片 6

图片 7

当表结构已存在时

一经要拉长约束的表已存在外键约束,须要先删除外键约束再添加外键约束。假诺不设有外键约束可以添加外键约束。

语法:

if exists(select * from sysobjects where
name=约束名)
alter table 数据库名.[dbo].表名 drop
constraint 约束名;
alter table 数据库名.[dbo].表名 with
check add constraint 约束名 foreign key(列名)
references 数据库名.[dbo].表名(列名)

on delete cascade
on update cascade;
go

示例:

if exists(select * from sysobjects where
name=’t1_t2′)
alter table [testss].[dbo].[test1]
drop constraint t1_t2;
alter table [testss].[dbo].[test1]
with check add constraint t1_t2 foreign key(classid)
references
[testss].[dbo].[test2](id)
on delete cascade
on update cascade;
go

图片 8

运用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

图片 9

图片 10

CHECK约束添加规则

一 、CHECK
约束用于限制列中的值的限制。

二 、Check约束通过逻辑表明式来判定数据的可行,用来限制输入一列或多列的值的限制,在列中立异数据时,所要输入的始末必须满足Check约束的标准,不然将不可能正确输入。

叁 、假设对单个列定义 CHECK
约束,那么该列只同意特定的值。

四 、假设对3个表定义 CHECK
约束,那么此约束会在一定的列中对值实行限制。

选用SSMS数据库管理工科具添加DEFAULT约束

① 、连接数据库,选择数据表-》右键点击-》采用设计。

图片 11

② 、在表设计窗口中-》选用数据列-》在列属性窗口中找到默许值或绑定-》输入暗中认可值(注意暗许值的数据类型和输入格式)。

图片 12

三 、点击保存按钮(或然ctrl+s)-》刷新表-》再一次打开表查看结果。

图片 13

动用T-SQL脚本添加外键约束

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图