定义
数据完整性用于保证数据库中数据的正确性、一致性和可靠性。
类型
• 实体完整性(Entity Integrity)
• 域完整性(Domain Integrity)
• 参照完整性(Referential Integrity)
• 用户定义完整性(User-defined Integrity)
图示
实体完整性(Entity Integrity)
实体完整性用于保证数据库中数据表的每一个特定实体的记录都是唯一的
域完整性(Domain Integrity)
域完整性是指保证指定列的数据具有正确的数据类型、格式和有效的数据范围。
参照完整性(Referential Integrity)
当增加、修改或删除数据库表中记录时,可以借助参照完整性来保证相关联表之间数据的一致性
用户定义完整性 (User- defined Integrity)
这是由用户定义的完整性。用户定义完整性可以定义不属于其他任何完整性分类的特定业务规则
数据完整性的实现方式
声明数据完整性和过程数据完整性
使用IDENTITY(标识符)列
语法格式:
CREATE TABEL 数据表名
(列名 列数据类型 IDENTITY [(种子, 增量)] [,…])
说明:标识种子为标识列的起始值,标识递增量为每次增加的数,二者的默认值均为1。
使用IDENTITY函数
语法格式:
IDENTITY ( 数据类型 [ , 种子 , 递增量 ] ) AS 列名
说明:只用在带有 INTO table 子句的 SELECT 语句中,可以将标识列插入到新表中。
尽管类似,但是 IDENTITY 函数不是与 CREATE TABLE 和 ALTER TABLE 一起使用的 IDENTITY 属性。
完整性类型 约束类型 描述
域 DEFAULT 指定列的默认值
CHECK 指定列的允许值
FOREIGN KEY 指定必须存在值的列
NULL 指定是否允许为NULL
实体 PRIMARY KEY 唯一标识每一行
UNIQUE 防止非主键重复
引用 FOREIGN KEY 定义值与同一个表或另一个表的主键值匹配的一列或多列组合
CHECK 指定根据同一个表中其他列的值可在列中接受的数据值
在SQL SERVER中,对于基本表的约束分为列约束和表约束。
完整性约束的基本语法格式为:
[CONSTRAINT constraint_name(约束名)] <约束类型>
约束不指定名称时,系统会给定一个名称。
在SQL Server 2005中有6种约束:主键约束(primary key constraint)、惟一性约束(unique constraint)、检查约束(check constraint)、默认约束(default constraint)、外部键约束(foreign key constraint)和空值(NULL)约束。
PRIMARY KEY 约束
PRIMARY KEY约束用于定义基本表的主键,它是惟一确定表中每一条记录的标识符,其值不能为NULL,也不能重复,以此来保证实体的完整性。PRIMARY KEY与UNIQUE约束类似,通过建立唯一索引来保证基本表在主键列取值的唯一性,但它们之间存在着很大的区别:
①一个表只能有一个 PRIMARY KEY 约束 ,但可定义多个UNIQUE约束;
②对于指定为PRIMARY KEY的一个列或多个列的组合,其中任何一个列都不能出现空值,而对于UNIQUE所约束的唯一键,则允许为空。
注意:不能为同一个列或一组列既定义UNIQUE约束,又定义PRIMARY KEY约束;
PRIMARY KEY既可用于列约束,也可用于表约束。
(2)使用Transact-SQL语句操作法设置主键约束,其语法形式如下:
PRIMARY KEY
CONSTRAINT constraint_name PRIMARY KEY ( column_name )
举例:建立一个SC表,定义SNO,CNO共同组成SC的主键
程序清单如下:
create table sc(
sno char(5) not null,
cno char(5) not null,
score numeric (3),
constraint sc_prim primary key(sno,cno)
)
UNIQUE约束
惟一性约束用于指定一个或者多个列的组合值具有惟一性,以防止在列中输入重复的值。定义了UNIQUE约束的那些列称为唯一键,系统自动为唯一键建立唯一索引,从而保证了唯一键的唯一性。
当使用惟一性约束时,需要考虑以下几个因素:
• 使用惟一性约束的字段允许为空值;
• 一个表中可以允许有多个惟一性约束;
• 可以把惟一性约束定义在多个字段上;
• 惟一性约束用于强制在指定字段上创建一个惟一性索引;
• 默认情况下,创建的索引类型为非聚集索引。
使用Transact-SQL语句完成惟一性约束的操作,其语法形式如下:
• UNIQUE
• CONSTRAINT constraint_name UNIQUE ( column_name )
CHECK 约束
检查约束对输入列或者整个表中的值设置检查条件,以限制输入值,保证数据库数据的完整性。
当使用检查约束时,应该考虑和注意以下几点:
• 一个列级检查约束只能与限制的字段有关;一个表级检查约束只能与限制的表中字段有关;
• 一个表中可以定义多个检查约束;
• 每个CREATE TABLE语句中每个字段只能定义一个检查约束;
• 在多个字段上定义检查约束,则必须将检查约束定义为表级约束;
• 当执行INSERT语句或者UPDATE语句时,检查约束将验证数据;
• 检查约束中不能包含子查询。
用Transact-SQL语句创建检查约束。其语法形式如下:
• CONSTRAINT constraint_name CHECK (logical_expression)
• CHECK (logical_expression)
create table sc(
sno char(5) not null,
cno char(5) not null,
score numeric(5,1) constraint score_chk check(score>=0 and score <=100),
constraint sc_prim primary key(sno,cno),
)
drop table sc
insert into sc values('1','2',3)
DEFAULT 约束
默认约束指定在插入操作中如果没有提供输入值时,则系统自动指定值。默认约束可以包括常量、函数、不带变元的内建函数或者空值。
使用默认约束时,应该注意以下几点:
(1)每个字段只能定义一个默认约束;
(2)如果定义的默认值长于其对应字段的允许长度,那么输入到表中的默认值将被截断;
(3)不能加入到带有IDENTITY属性或者数据类型为timestamp的字段上;
(4)如果字段定义为用户定义的数据类型,而且有一个默认绑定到这个数据类型上,则不允许该字段有默认约束。
创建默认约束的Transact-SQL语句操作法。其语法形式如下:
• CONSTRAINT constraint_name DEFAULT constraint_expression [FOR column_name]
• DEFAULT constraint_expression [FOR column_name]
举例:为 dept字段创建默认约束。
程序清单如下:
constraint con_dept default ‘计算机’ for dept
NULL 约束
空值约束用来控制是否允许该字段的值为NULL。NULL值不是0也不是空白,更不是填入字符串的“NULL”字符串,而是表示“不知道”、“ 不确定”或“没有数据”的意思。
当某一字段的值一定要输入才有意义的时候,则可以设置为NOT NULL。如主键列就不允许出现空值,否则就失去了唯一标识一条记录的作用。空值约束只能用于定义列约束。
FOREIGN KEY 约束
FOREIGN KEY约束是用于建立和加强两个表数据之间的链接的一列或多列。外部键约束用于强制参照完整性。
FOREIGN KEY 约束确保同一个表或者不同表之间的引用完整性
必须引用一个PRIMARY KEY或者UNIQUE约束
用户必须在应用表上具有REFERENCES权限
一个表中最多可以有31个外部键约束;
在临时表中,不能使用外部键约束;
主键和外部键的数据类型必须严格匹配 。
使用Transact-SQL语句设置外部键约束 ,其语法形式如下:
CONSTRAINT constraint_name
FOREIGN KEY (column_name[,…n])
REFERENCES ref_table [(ref_column[,…n])]
ALTER TABLE [Sales].[SalesOrderHeader] WITH CHECK
ADD CONSTRAINT [FK_SalesOrderHeader_Customer_CustomerID]
FOREIGN KEY([CustomerID])
REFERENCES [Sales].[Customer] ([CustomerID])
禁用 CHECK 和 FOREIGN KEY 约束:
当运行大型批处理作业时提高性能
当向表中添加新的约束的时候避免检查已经存在的数据