3、如果对单个列定义 CHECK

CHECK约束增加法则

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

2、Check约束通过逻辑表明式来推断数据的卓有成效,用来界定输入一列或多列的值的限量,在列中更新数据时,所要输入的开始和结果必须满意Check约束的准则,不然将不可能准确输入。

3、尽管对单个列定义 CHECK
约束,那么该列只允许特定的值。

4、要是对贰个表定义 CHECK
约束,那么此约束会在特定的列中对值实行限制。

采纳SSMS数据库处理工科具增多CHECK约束

1、连接数据库,选拔数据库,接纳数据表-》右键点击(恐怕直接点击约束,右键点击,采纳丰硕约束,后边步骤同样)-》采纳设计。

图片 1

2、选取要增加约束的数目列-》右键点击-》选用CHECK约束。

图片 2

3、在CHECK约束弹出框中式点心击增添。

图片 3

4、在CHECK约束弹出框中-》输入CHECK约束表达式-》输入CHECK约束名-》输入CHECK约束描述-》别的能够采用私下认可。

图片 4

5、点击关闭-》点击保存按键(或然ctrl+s)-》刷新表查看结果。

图片 5

选取T-SQL脚本增加CHECK约束

当表结构存在时

增多CHECK约束时首先校验约束是还是不是已存在,即便存在应该是先删除再增添,借使空头支票则直接助长。

语法:

— 增多一个私下认可约束
use 数据库名;
go

if exists(select * from sysobjects where
name=约束名)
alter table 表名 drop constraint
约束名;
go

alter table 表名 add constraint 约束名
check(约束准绳),constraint 约束名 check(约束法规);
go

示例:

— 加多八个暗许约束
use testss;
go

if exists(select * from sysobjects where
name=’check1′)
alter table test1 drop constraint
check1;
go

alter table test1 add constraint check1
check(height>=170 and height<=175);
go

 图片 6

图片 7

当表结构空头支票时

万一表结构空中楼阁,能够一直抬高约束,能够同不常候丰硕三个依旧多个约束。

语法:

–假使表结构不设有的时候加多check约束
use 数据库名;
go
–如若已存在表则删除
if exists(select * from sysobjects where
name=表名 and xtype=’U’)
drop table 表名;
go
–创建表
create table 表名
(
–字段证明
列名 int identity(1,1) not null,
列名 nvarchar(50) null,
列名 nvarchar(50) null constraint 约束名
check(约束法规),
列名 nvarchar(50) null,
列名 int,
列名 int constraint 约束名
check(约束准绳)
primary key clustered(列名 asc)
with(ignore_dup_key=off) on [primary], –主键索引表明
)on [primary]

–字段注释声明
exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’列描述’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’表名’,
@level2type=N’COLUMN’,@level2name=N’列名’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’列描述’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’表名’,
@level2type=N’COLUMN’,@level2name=N’列名’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’列描述’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’表名’,
@level2type=N’COLUMN’,@level2name=N’列名’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’列描述’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’表名’,
@level2type=N’COLUMN’,@level2name=N’列名’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’列描述’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’表名’,
@level2type=N’COLUMN’,@level2name=N’列名’;

go

示例:

–假设表结构不设不常加多check约束
use testss;
go
–假设已存在表则删除
if exists(select * from sysobjects where
name=’test1′ and xtype=’U’)
drop table test1;
go
–创建表
create table test1
(
–字段注脚
id int identity(1,1) not null,
name nvarchar(50) null,
sex nvarchar(50) null constraint check1
check(sex=’男’ or sex=’女’),
age nvarchar(50) null,
classid int,
height int constraint check2
check(height>=110 and height<=120)
primary key clustered(id asc)
with(ignore_dup_key=off) on [primary], –主键索引注明
)on [primary]

–字段注释注明
exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’id主键’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’id’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’姓名’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’name’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’性别’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’sex’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’年龄’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’age’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’班级id’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’classid’;

go

 图片 8

图片 9

图片 10

CHECK约束优劣势

优点:

1、保险列数据标准和限量,可以约束数据完整性

2、有Check约束的列能够提须要查询优化器新闻之所以升级品质

缺点:

1、插入恐怕修改时数据不符合约束准绳,不可能修改成功。

相关文章