- 王珊《数据库系统概论》(第4版)【教材精讲+考研真题解析】讲义与视频课程【28小时高清视频】
- 圣才电子书
- 1771字
- 2021-06-04 18:05:01
2.3 关系的完整性
视频二维码(扫码观看)
2.3.1 关系的三类完整性约束
·实体完整性和参照完整性:
关系模型必须满足的完整性约束条件
称为关系的两个不变性,应该由关系系统自动支持
·用户定义的完整性:
应用领域需要遵循的约束条件,体现了具体领域中的语义约束
2.3.2 实体完整性
【规则2.1】实体完整性规则(Entity Integrity)
若属性A是基本关系R的主属性,则属性A不能取空值
例:SAP(SUPERVISOR,SPECIALITY,POSTGRADUATE)
POSTGRADUATE:主码(假设研究生不会重名)不能取空值。
实体完整性规则的说明:
(1)实体完整性规则是针对基本关系而言的。一个基本表通常对应现实世界的一个实体集。
(2)现实世界中的实体是可区分的,即它们具有某种唯一性标识。
(3)关系模型中以主码作为唯一性标识。
(4)主码中的属性即主属性不能取空值。
主属性取空值,就说明存在某个不可标识的实体,即存在不可区分的实体,这与第(2)点相矛盾,因此这个规则称为实体完整性。
注意:实体完整性规则规定基本关系的所有主属性都不能取空值,而不仅是主码整体不能取空值。
例:选修(学号,课程号,成绩)
“学号、课程号”为主码,则学号和课程号两个属性都不能取空值。
2.3.3 参照完整性
1关系间的引用
在关系模型中实体及实体间的联系都是用关系来描述的,存在着关系与关系间的引用。
【例1】学生实体、专业实体
学生(学号,姓名,性别,专业号,年龄)
专业(专业号,专业名)
·学生关系引用了专业关系的主码“专业号”。
·学生关系中的“专业号”值必须是确实存在的专业的专业号,即专业关系中有该专业的记录。
【例2】学生、课程、学生与课程之间的多对多联系
学生(学号,姓名,性别,专业号,年龄)
课程(课程号,课程名,学分)
选修(学号,课程号,成绩)
学生:
课程:
学生选课:
【例3】学生实体及其内部的一对多联系
学生(学号,姓名,性别,专业号,年龄,班长)
·“学号”是主码,“班长”是外码,它引用了本关系的“学号”;
·“班长”必须是确实存在的学生的学号。
2外码(Foreign Key)
·设F是基本关系R的一个或一组属性,但不是关系R的码。如果F与基本关系S的主码Ks相对应,则称F是基本关系R的外码
·基本关系R称为参照关系(Referencing Relation)
·基本关系S称为被参照关系(Referenced Relation)或目标关系(Target Relation)
【例1】学生关系的“专业号”与专业关系的主码“专业号”相对应
·“专业号”属性是学生关系的外码;
·专业关系是被参照关系,学生关系为参照关系。
【例2】选修关系的“学号”与学生关系的主码“学号”相对应;
选修关系的“课程号”与课程关系的主码“课程号”相对应。
·“学号”和“课程号”是选修关系的外码;
·学生关系和课程关系均为被参照关系;
·选修关系为参照关系。
【例3】“班长”与本身的主码“学号”相对应。
·“班长”是外码;
·学生关系既是参照关系也是被参照关系。
说明:
·关系R和S不一定是不同的关系;
·目标关系S的主码Ks和参照关系的外码F必须定义在同一个(或一组)域上;
·外码并不一定要与相应的主码同名,当外码与相应的主码属于不同关系时,往往取相同的名字,以便于识别。
3参照完整性规则
【规则2.2】参照完整性规则
若属性(或属性组)F是基本关系R的外码,它与基本关系S的主码Ks相对应(基本关系R和S不一定是不同的关系),则对于R中每个元组在F上的值必须为:
·或者取空值(F的每个属性值均为空值);
·或者等于S中某个元组的主码值。
【例1】学生关系中每个元组的“专业号”属性只取两类值:
(1)空值,表示尚未给该学生分配专业;
(2)非空值,这时该值必须是专业关系中某个元组的“专业号”值,表示该学生不可能分配一个不存在的专业。
【例2】选修(学号,课程号,成绩)
“学号”和“课程号”可能的取值:
(1)选修关系中的主属性,不能取空值;
(2)只能取相应被参照关系中已经存在的主码值。
【例3】学生(学号,姓名,性别,专业号,年龄,班长)
“班长”属性值可以取两类值:
(1)空值,表示该学生所在班级尚未选出班长;
(2)非空值,该值必须是本关系中某个元组的学号值。
2.3.4 用户定义的完整性
·针对某一具体关系数据库的约束条件,反映某一具体应用所涉及的数据必须满足的语义要求。
·关系模型应提供定义和检验这类完整性的机制,以便用统一的系统的方法处理它们,而不要由应用程序承担这一功能。
例:课程(课程号,课程名,学分)
“课程号”属性必须取惟一值,非主属性“课程名”也不能取空值,“学分”属性只能取值{1,2,3,4}。