欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

SQLServer之CHECK约束

程序员文章站 2022-03-12 10:52:12
CHECK约束添加规则 1、CHECK 约束用于限制列中的值的范围。 2、Check约束通过逻辑表达式来判断数据的有效性,用来限制输入一列或多列的值的范围,在列中更新数据时,所要输入的内容必须满足Check约束的条件,否则将无法正确输入。 3、如果对单个列定义 CHECK 约束,那么该列只允许特定的 ......

check约束添加规则

1、check 约束用于限制列中的值的范围。

2、check约束通过逻辑表达式来判断数据的有效性,用来限制输入一列或多列的值的范围,在列中更新数据时,所要输入的内容必须满足check约束的条件,否则将无法正确输入。

3、如果对单个列定义 check 约束,那么该列只允许特定的值。

4、如果对一个表定义 check 约束,那么此约束会在特定的列中对值进行限制。

使用ssms数据库管理工具添加check约束

1、连接数据库,选择数据库,选择数据表-》右键点击(或者直接点击约束,右键点击,选择添加约束,后面步骤相同)-》选择设计。

SQLServer之CHECK约束

2、选择要添加约束的数据列-》右键点击-》选择check约束。

SQLServer之CHECK约束

3、在check约束弹出框中点击添加。

SQLServer之CHECK约束

4、在check约束弹出框中-》输入check约束表达式-》输入check约束名-》输入check约束描述-》其他可以选择默认。

SQLServer之CHECK约束

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

SQLServer之CHECK约束

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

 SQLServer之CHECK约束

SQLServer之CHECK约束

当表结构不存在时

如果表结构不存在,可以直接添加约束,可以同时添加一个或者多个约束。

语法:

--如果表结构不存在时添加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

 SQLServer之CHECK约束

SQLServer之CHECK约束

SQLServer之CHECK约束

check约束优缺点

优点:

1、保证列数据规范和范围,可以约束数据完整性

2、有check约束的列可以提供给查询优化器信息从而提升性能

缺点:

1、插入或者修改时数据不符合约束规则,无法修改成功。