SQLServer约束介绍

发布时间:2018-11-15  栏目:SQL  评论:0 Comments

DEFAULT约束添加规则

1、若于说明中定义了默认值约束,用户在插入新的数码时,如果该行没有点名数量,那么网将默认值赋给该列,如果我们无设置默认值,系统默认为NULL。

2、如果“默认值”字段被之项替换绑定的默认值(以无牵动圆括号的款型展示),则将唤起您解除对默认值的绑定,并以那替换为新的默认值。

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

4、若一旦输入数值默认值,请输入数值并且毫不为此引号将值括起来。

5、若一旦输入对象/函数,请输入对象/函数的称呼并且永不为此引号将名称括起来。

约定义

对于数据库来说,基本表的完整性约束分为列级约束原则与表级约束规范:

列级约束规范

     
 列级约束规范是指向有一个一定列的律,包含在列定义中,可以一直与于该列的别概念之后,用空格分隔,不用指定列名。

表级约束原则

     
 表级约束原则与列定义相互独立,不包括在列定义中,通常用于对有限只或个别只以上的排列一起展开封锁。

动SSMS数据库管理工具添加DEFAULT约束

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

图片 1

2、在表明设计窗口中-》选择数据列-》在列属性窗口中找到默认值或绑定-》输入默认值(注意默认值的数据类型和输入格式)。

图片 2

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

图片 3

律介绍

在数据库管理网遭到,保证数据库中的数据完整性是十分关键之。所谓数据完整性,就是凭借储存在数据库被数量的一致性与对。约束定义关于列中允许值的平整,是挟持完整性的正规机制。使用约束优先受以触发器、规则和默认值。查询优化器也应用约束定义生成高性能的查询执行计划。

数据完整性分类

于SQL
Server中,根据数量完全新章程所打算的数据库对象及限不同,可以拿数据完整性分为以下几栽:

实体完整性

实业完整性简单的游说,就是用表中的诸一行看作一个实体。实体完整性要求说明的标记符列或主键的完整性。可以由此建唯一索引、PRIMARY
KEY约束、UNIQUE约束,以及列的IDENTITY属性来执行实体完整性。

地段完整性

地区完整性是因于定列的输入有效性。要求表中指定列的多少具有无可争辩的数据类型、格式和管事的多寡范围。强制域有效性的不二法门有:限制类(通过数量类)、格式(通过
CHECK 约束与规则)或可能价值的范围。域完整性通过 FOREIGN KEY 约束、CHECK
约束、DEFAULT 定义、NOT NULL 定义和规则来落实。

援完整性

援完整性又如参照完整性。引用完整性维持为参照表和参照表之间的数码一致性,它通过主键(PRIMARY
KEY)约束和外键(FOREIGN
KEY)约束来贯彻。引用完整性确保键值在享有表中一致。这样的一致性要求不能引用不存在的价值,如果键值更改了,那么当全数据库被,对该键值的装有援要进行同样的反。在受参照表中,当其主键值为别表所参照时,该行未可知叫剔除也无同意改变。在参考表中,不允参照不有的主键值。

运用T-SQL脚论上加DEFAULT约束

自律分类

SQLServer中发出五栽约束类型,分别是 PRIMARY
KEY约束、FOREIGN
KEY约束、UNIQUE约束、DEFAULT约束、和CHECK约束。查看或创造约束都设采用及
Microsoft SQL Server Managment Studio。

当表结构就在时时

率先判断表中是否有默认约束,如果有则先去默认约束再添加,如果未存在则直抬高。

语法:

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

图片 4

图片 5

PRIMARY KEY约束

在表明中常发出同一排或多排的咬合,其值能唯一标识表中之每一样实施,这样的同样排或多排成表底主键(PrimaryKey)。

一个阐明只能有一个主键,而且主键约束中的排列不可知为空值。

除非主键列才能够叫当做其它表底外键所创建。

开创表时长默认约束

首先判断表是否选在,如果在则先删除表再补偿加,如果无在则直抬高。

语法:

–创建新表时上加默认约束
–数据库声明
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

图片 6

图片 7

FOREIGN KEY约束 

外键约束是因此来增进两只说明(主表和从表)的平等排或多排数据里的总是的。

创立外键约束的依次是先定义主表的主键,再对由表定义外键约束。

除非主表的主键才能够让由表用来作外键使用,被封锁之于表中的排列好不是主键,主表限制了从表更新与插的操作。

DEFAULT约束优缺点

优点:

1、使用默认值可以削减代码量,新增多少时方可不用写新增默认值列,执行新增操作时时默认填充。

2、较有利开展统计和剖析,以及方便程序逻辑操作。

缺点:

1、使用非也NULL的默认值,占用了重新多的囤空间。

 

UNIQUE约束

唯一约束保证表中的一样列数据尚未一样之价值。

和主键约束类似,唯一约束为强制唯一性,但唯一约束用于非主键的平等排或者基本上排的构成,且一个表明得定义多单唯一约束。

DEFAULT约束

假如以表明中定义了默认值约束,用户在插入新的数时,如果该行没有点名数量,那么网将默认值赋给该列,如果我们无装默认值,系统默认为NULL。

CHECK约束

CHECK 约束用于限制列被的值的限量。

Check约束通过逻辑表达式来判定数的卓有成效,用来限制输入一排或多排的价的限制,在列被更新数据经常,所要输入的情节必须满足Check约束的基准,否则将无法对输入。

一旦对单个列定义 CHECK
约束,那么该列只同意特定的值。

只要对一个表定义 CHECK
约束,那么这约束会在一定的列中对值进行限定。

约优缺点

优点:

1、保持数据库完整性。

2、保证列着数量的唯一性。

3、插入、更新、删除时严厉的限制校验机制。

4、快速。

5、可以引用其他列。

6、在命令执行前出。

7、遵循ANSI标准。

缺点:

1、插入、更新、删除时用校验规则比较费心。

2、必须对每个表还定义。

3、不能引用其他表。

4、不能够绑定到数据类型。

 

留下评论

网站地图xml地图