SQLServer之CHECK约束

FOREIGN KEY 约束只能列出一个引用列,则此值必须在被引用列中存在,请输入数值并且不要用引号将值括起来,请输入对象/函数的名称并且不要用引号将名称括起来,用来限制输入一列或多列的值的范围,选择数据表-》右键点击(或者直接点击约束,向表中添加字段,添加唯一约束

图片 27

在新表中开创外键

 语法:

if exists( select * from sysobjects where
name=表名 and type =’U’)
drop table 表名;
go

–当表结构不设有时
–建表语法注脚
create table 表名
(
–字段注明
列名 int identity(1,1) not null,
列名 int,
primary key clustered(id asc)
with(ignore_dup_key=off) on [primary], –主键索引注脚
constraint 外键名 foreign key(列名)

references 主表名(列名)
on update cascade–是或不是级联操作
on delete cascade
)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’列名’;

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,
primary key clustered(id asc)
with(ignore_dup_key=off) on [primary], –主键索引注解
constraint t3_t4 foreign key(classid)

references test2 (id)
on update cascade
on delete cascade
)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

图片 1

DEFAULT约束添加规则

壹 、若在表中定义了暗中认可值约束,用户在插入新的数量行时,假如该行没有点名数量,那么系统将默许值赋给该列,要是大家不安装暗中同意值,系统暗许为NULL。

二 、假若“默许值”字段中的项替换绑定的暗中同意值(以不带圆括号的款型体现),则将唤起您解决对暗中认可值的绑定,并将其替换为新的默许值。

三 、若要输入文本字符串,请用单引号 (‘)
将值括起来;不要使用双引号
(“),因为双引号已保存用于带引号的标识符。

④ 、若要输入数值私下认可值,请输入数值并且永不用引号将值括起来。

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

CHECK约束添加规则

① 、CHECK
约束用于限制列中的值的界定。

二 、Check约束通过逻辑表明式来判断数据的有用,用来限制输入一列或多列的值的限制,在列中更新数据时,所要输入的始末必须满意Check约束的规范,不然将无法正确输入。

③ 、如若对单个列定义 CHECK
约束,那么该列只同意特定的值。

四 、倘诺对一个表定义 CHECK
约束,那么此约束会在一定的列中对值进行限制。

Alter table [表名] add constraint [约束名] default(默认值) for
[列名]
7:添加约束

FOREIGN KEY约束优缺点

优点:

壹 、保证数据的一致性,完整性,更可相信。

② 、关联合检查询时,能够用到FK 的总结音讯。

叁 、有主外键的数据库设计能够扩大EOdyssey图的可读性。

缺点:

壹 、删队或更新关联数据时索要做检查,功效会十分低。

② 、手工业调数据时,会存在主从表校验,会比较辛勤。

叁 、批量导入数据时,会存在外键校验,必要先关闭外键约束,导入完成再打开外键约束,操作相比较麻烦。

 

DEFAULT约束优缺点

优点:

① 、使用暗中认可值能够减弱代码量,新增多少时方可不用写新增暗中同意值列,执行新增操作时时暗中认可填充。

贰 、较有利开始展览总结和分析,以及方便程序逻辑操作。

缺点:

壹 、使用不为NULL的默许值,占用了愈多的仓库储存空间。

 

当表结构不设有时

借使表结构不存在,能够直接助长约束,能够同时加上3个照旧多少个约束。

语法:

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

 图片 2

图片 3

图片 4

exec sp_rename ‘[原表名]’,'[新表名]’

行使T-SQL脚本添加外键约束

接纳SSMS数据库管理工科具添加DEFAULT约束

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

图片 5

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

图片 6

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

图片 7

行使SSMS数据库管理工科具添加CHECK约束

一 、连接数据库,选拔数据库,选取数据表-》右键点击(或许直接点击约束,右键点击,选用足够约束,前边步骤一样)-》选用设计。

图片 8

贰 、选择要增进约束的多寡列-》右键点击-》选用CHECK约束。

图片 9

三 、在CHECK约束弹出框中点击添加。

图片 10

④ 、在CHECK约束弹出框中-》输入CHECK约束表明式-》输入CHECK约束名-》输入CHECK约束描述-》其余能够挑选默许。

图片 11

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

图片 12

Alter table [表名] add constraint [约束名] check (内容)

当表结构已存在时

设若要加上约束的表已存在外键约束,必要先删除此而外键约束再添加外键约束。假诺不设有外键约束能够添加外键约束。

语法:

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

图片 13

创立表时拉长默许约束

第1判断表是不是选在,假如存在则先删除表再添加,借使不设有则直接助长。

语法:

–成立新表时添加暗中认可约束
–数据库申明
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

图片 14

图片 15

CHECK约束优缺点

优点:

一 、保险列数据标准和界定,可以约束数据完整性

贰 、有Check约束的列能够提供给查询优化器音讯之所以升级质量

缺点:

一 、插入只怕涂改时数据不符合约束规则,不恐怕修改成功。

 

FOREIGN KEY约束添加规则

一 、外键约束并不仅仅能够与另一表的主键约束相链接,它还是能定义为引用另3个表中
UNIQUE 约束的列。

贰 、假设在 FOREIGN
KEY 约束的列中输入非 NULL
值,则此值必须在被引用列中存在;不然,将回到违反外键约束的错误新闻。 若要保管验证了整合外键约束的有所值,请对负有参加列钦赐NOT NULL。

叁 、FOREIGN KEY
约束仅能引用位于同一服务器上的同样数据库中的表。 跨数据库的引用完整性必须透过触发器完成。

肆 、FOREIGN KEY
约束可援引同一表中的别的列。 此行为称为自引用。

五 、在列级内定的
FOREIGN KEY 约束只可以列出四个引用列。 此列的数据类型必须与概念约束的列的数据类型相同。

陆 、在表级钦定的
FOREIGN KEY 约束所全部的引用列数目必须与约束列列表中的列数相同。 各样引用列的数据类型也不可能不与列表中相应列的数据类型相同。

七 、对于表可包涵的引用其余表的 FOREIGN KEY
约束的多寡或任何表所拥有的引用特定表的 FOREIGN KEY 约束的数据, 数据库引擎 都尚未预约义的范围。 就算如此,可选取的 FOREIGN KEY
约束的骨子里数据照旧受硬件配备以及数据库和应用程序设计的限量。 表最多能够将 253个其余表和列作为外键引用(传出引用)。 SQL
Server 二零一六 (13.x) 将可在单身的表中引用的其他表和列(传入引用)的多寡限制从
253 升高至 10,000。 (包容性级别至少必须为
130。)数量限制的增强带来了下列约束:

DELETE 和 UPDATE
DML 操作帮助胜出 253 个外键引用。 不补助ME奥迪Q7GE 操作。

对自己实行外键引用的表仍只可以进行 25一个外键引用。

列存款和储蓄索引、内部存款和储蓄器优化表和 Stretch Database
暂不支持开始展览超越 253 个外键引用。

⑧ 、对于权且表不强制 FOREIGN KEY 约束。

⑨ 、假使在 CL本田UR-V用户定义类型的列上定义外键,则该项目标落到实处必须援救二进制排序。

⑩ 、仅当 FOREIGN
KEY
约束引用的主键也定义为品种 varchar(max) 时,才能在此约束中使用项目为varchar(max) 的列。

当表结构已存在时

率先判断表中是不是存在暗中认可约束,假如存在则先删除私下认可约束再添加,假如不设有则直接助长。

语法:

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

图片 16

图片 17

当表结构存在时

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

 图片 18

图片 19

3:  修改表中字段类型 (可以修改列的项目,是不是为空)

使用SSMS数据库管理工科具添加外键约束

本示例演示当表结构已存在时添加外键约束,创立表时增进外键约束步骤和表结构存在时添加外键步骤一样。示例演示如下:

① 、连接数据库,打开要添加外键的多少表-》右键点击-》接纳设计。

图片 20

二 、在表设计窗口-》选择要添加外键的数目行-》右键点击-》选拔事关。

图片 21

叁 、在外键关系窗口中-》点击添加。

图片 22

四 、添加实现后-》首先修改表和列规范。

图片 23

五 、在表和列窗口中-》输入外键名-》在左边选用主表和事关的列-》在左侧采用从表和作为外键的列-》点击鲜明。

图片 24

六 、在外键关系窗口中-》可采纳充分或然不添加外键描述-》可挑选丰硕只怕不添加修改大概去除数据时级联操作-》可选择足够或许不添抓实制外键约束-》可挑选丰盛只怕不添抓实制用于复制-》点击关闭。

图片 25

七 、点击保存按钮(ctrl+s)-》此时表会弹出警告窗口,点击是-》刷新查看外键是或不是丰硕成功。

图片 26

图片 27

使用T-SQL脚本添加DEFAULT约束

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

Alter table [表名] add constraint [ 约束名] primary key( [列名])

12:为表添加描述消息
EXECUTE sp_addextendedproperty N’MS_Description’, ‘职员音信表’,
N’user’, N’dbo’, N’TABLE’, N’表名’, NULL, NULL