数据库知识整理<三>

时间:2024-07-31 11:07:02

保证数据的完整性:


3.1数据完整性概述:

  数据完整性的意义:我们知道数据库能防止储存垃圾数据,RDBMS实现该功能主要是通过维护数据完整性来实现的。根据数据完整性实施方法我们将其分为四类:实体完整性、域完整性、引用完整性、自定义的完整性。

  1. 实体完整性:一个表中的一行和它代表的一行完全一致,那么我们就说该表具有完整性。
  2. 域完整性:指给定列的输入有效性,如:限制类型(通过数据类型)、格式(检查约束)、可能值(外简约束、检查约束、默认值定义、非空约束)。
  3. 引用完整性:实体与实体之间的联系在表中用外键表示。
  4. 自定义完整性:可以自定义不属于其他任何完整性分类的特定业务规则。

3.2数据完整性的实现:

  1. 创建非空约束,字段后面加not null如:id int not null;
  2. 设置主键约束,primary key如:id int primary key not null;
  3. 设置唯一约束,unique如:phoneNo varchar(11) unique;
  4. 指定默认值,default如:address varchar(30) default '不知道电话号码' not null;
  5. 设置检查约束,check给定插入数据一个范围要求。如:Age int check (Age between 10 and 100);年龄范围在10到100岁之间。
  6. 使用自动编号,identity如:id int identity(1000 1) primary key not null;自动编号1到1000。
  7. 理解引用完整性和外键约束foreign key 约束链接的两个列必须是相同的数据类型。如:有两张表friend和phone。friend表中有主键friendId,phone表中有字段friendId,那么建立外键形式如:foreign key (friendId) references friend(friendId);此外键是健在表phone中的,前面的friendId是指phone表中的字段friedId,后面才是friend表中的主键friendId。有外键约束的表是不能删除被其他表引用的表,如果要删除首先必须是去掉引用关系。
  8. 对已经存在的表实施数据完整性。前面我们知道可以通过alter table 添加或者删除列,当然也可以添加、删除主键、外键、其他约束。语法如:alter table friend drop constraint unq_name;(删除唯一约束)。又如:alter table friend add constraint pk_friendName primary key(name);(添加主键约束语句)

总结上述知识:非空、主键约束、唯一约束、自动编号、外键约束等是经常会用到的。这些知识是必备的技能,被问到的可能性相对较低。