数据库知识整理<三>
保证数据的完整性:
3.1数据完整性概述:
数据完整性的意义:我们知道数据库能防止储存垃圾数据,RDBMS实现该功能主要是通过维护数据完整性来实现的。根据数据完整性实施方法我们将其分为四类:实体完整性、域完整性、引用完整性、自定义的完整性。
- 实体完整性:一个表中的一行和它代表的一行完全一致,那么我们就说该表具有完整性。
- 域完整性:指给定列的输入有效性,如:限制类型(通过数据类型)、格式(检查约束)、可能值(外简约束、检查约束、默认值定义、非空约束)。
- 引用完整性:实体与实体之间的联系在表中用外键表示。
- 自定义完整性:可以自定义不属于其他任何完整性分类的特定业务规则。
3.2数据完整性的实现:
- 创建非空约束,字段后面加not null如:id int not null;
- 设置主键约束,primary key如:id int primary key not null;
- 设置唯一约束,unique如:phoneNo varchar(11) unique;
- 指定默认值,default如:address varchar(30) default '不知道电话号码' not null;
- 设置检查约束,check给定插入数据一个范围要求。如:Age int check (Age between 10 and 100);年龄范围在10到100岁之间。
- 使用自动编号,identity如:id int identity(1000 1) primary key not null;自动编号1到1000。
- 理解引用完整性和外键约束foreign key 约束链接的两个列必须是相同的数据类型。如:有两张表friend和phone。friend表中有主键friendId,phone表中有字段friendId,那么建立外键形式如:foreign key (friendId) references friend(friendId);此外键是健在表phone中的,前面的friendId是指phone表中的字段friedId,后面才是friend表中的主键friendId。有外键约束的表是不能删除被其他表引用的表,如果要删除首先必须是去掉引用关系。
- 对已经存在的表实施数据完整性。前面我们知道可以通过alter table 添加或者删除列,当然也可以添加、删除主键、外键、其他约束。语法如:alter table friend drop constraint unq_name;(删除唯一约束)。又如:alter table friend add constraint pk_friendName primary key(name);(添加主键约束语句)
总结上述知识:非空、主键约束、唯一约束、自动编号、外键约束等是经常会用到的。这些知识是必备的技能,被问到的可能性相对较低。