数据库

当前位置:澳门新莆京娱乐官网 > 数据库 > SQLServer之CHECK约束

SQLServer之CHECK约束

来源:http://www.drgigabytes.com 作者:澳门新莆京娱乐官网 时间:2019-12-28 22:20

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]

--字段注释证明
SQLServer之CHECK约束。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、插入大概涂改时数据不合乎约束法则,不或许修正成功。

本文由澳门新莆京娱乐官网发布于数据库,转载请注明出处:SQLServer之CHECK约束

关键词: