CHECK节制增多准则

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

2、Check节制通过逻辑表达式来推断数据的实用,用来限定输入一列或多列的值的范围,在列中修改数据时,所要输入的内容必需满意Check约束的基准,否则将无法正确输入。

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

4、若是对三个表定义 CHECK
节制,那么此节制会在一定的列中对值进行界定。

DEFAULT约束增加准则

1、若在表中定义了暗中同意值节制,客户在插入新的数据行时,假如该行未有一点点名数量,那么系统将私下认可值赋给该列,借使大家不安装暗许值,系统默认为NULL。

2、倘使“私下认可值”字段中的项替换绑定的暗中同意值(以不带圆括号的样式显得),则将唤起您消释对私下认可值的绑定,并将其替换为新的私下认可值。

3、若要输入文本字符串,请用单引号 (‘卡塔尔将值括起来;不要使用双引号
(“State of Qatar,因为双引号已保存用于带引号的标记符。

4、若要输入数值暗许值,请输入数值並且不要用引号将值括起来。

5、若要输入对象/函数,请输入对象/函数的名目并且永不用引号将名称括起来。

接纳SSMS数据库管理工科具加多CHECK约束

1、连接数据库,选取数据库,接受数据表-》右键点击(大概直接点击限定,右键点击,选用丰裕限制,后边步骤同样卡塔尔国-》选用设计。

图片 1

2、选用要增加节制的数码列-》右键点击-》接收CHECK约束。

图片 2

3、在CHECK限制弹出框中式点心击增加。

图片 3

4、在CHECK约束弹出框中-》输入CHECK节制表达式-》输入CHECK节制名-》输入CHECK限制描述-》其余能够接纳暗中同意。

图片 4

5、点击关闭-》点击保存开关(大概ctrl+sState of Qatar-》刷新表查看结果。

图片 5

应用SSMS数据库管理工科具增添DEFAULT节制

1、连接数据库,选用数据表-》右键点击-》接收设计。

图片 6

2、在表设计窗口中-》接受数据列-》在列属性窗口中找到暗中认可值或绑定-》输入暗许值(注意默许值的数据类型和输入格式卡塔尔国。

图片 7

3、点击保存开关(或然ctrl+s卡塔尔(قطر‎-》刷新表-》再度张开表查看结果。

图片 8

利用T-SQL脚本增添CHECK约束

运用T-SQL脚本增加DEFAULT约束

当表布局存在时

加多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

 图片 9

图片 10

当表构造已存在时

先是剖断表中是不是留存私下认可限制,如若存在则先删除暗中认可约束再增加,假如不设有则一贯抬高。

语法:

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

图片 11

图片 12

当表构造不设有时

假定表结构官样文章,能够一向抬高度大概束,能够同不经常间丰硕三个依然八个节制。

语法:

–借使表构造不设一时增添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

 图片 13

图片 14

图片 15

开创表时加上私下认可约束

率先判定表是还是不是选在,假诺存在则先删除表再加多,假使空中楼阁则直接助长。

语法:

–创建新表时增加私下认可节制
–数据库注解
use 数据库名
go
–借使表已存在则先删除表再次创下立,假如表一纸空文则直接开立
if exists(select * from sysobjects where
name=表名 and type =’U’)
drop table 表名;
go
–建表语法评释
create table 表名
(
–字段评释
列名 列类型 identity(1,1) not
null,
列名 列类型) null,
列名 列类型 null,
列名 列类型 null,
列名 列类型,
列名 列类型 constraint 约束名 default
默认值,
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

示例:

–创立新表时增添暗中认可约束
–数据库注明
use testss
go
–固然表已存在则先删除表再次创下制,如若表子虚乌有则直接成立
if exists(select * from sysobjects where
name=’test1′ and type =’U’)
drop table test1;
go
–建表语法注解
create table test1
(
–字段证明
id int identity(1,1) not null,
name nvarchar(50) null,
sex nvarchar(50) null,
age nvarchar(50) null,
classid int,
height int constraint default_he default
166,
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

图片 16

图片 17

CHECK约束优劣势

优点:

1、保证列数据正式和限定,能够约束数据完整性

2、有Check节制的列能够提须求查询优化器消息之所以晋级质量

缺点:

1、插入或许修正时数据不相符节制准绳,不可能订正成功。

DEFAULT约束优劣势

优点:

1、使用默许值可以减小代码量,新扩展多少时能够不用写新扩大暗中同意值列,推行新扩大操作时时暗中同意填充。

2、较有扶助开展总计和剖析,以至福利程序逻辑操作。

缺点:

1、使用不为NULL的私下认可值,占用了越多的蕴藏空间。

 

发表评论

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

相关文章