E-R模型向关系模型的转换规则:

转换准则:1:1、1:N、M:N

二元联系

(1)一对一关系(One to One)

当转换为关系模型时,在两个实体任选一个添加另一个实体的主键即可。

例子:校里一个班级只有一个正班长,而一个班长只在一个班中任职,则班级与班长之间具有一对一联系。当转换为关系模式时,我们可以在班长关系中添加班级的主键(班级号);或者在班级关系中添加班长的主键(学号)。

(2)多对一关系(Many to one)

保留多边(Many-side)E1的所有属性 + 一边(one-side)的主键 + 关系自身的属性到一个扩展(extended)的E1表中。

即当转换为关系模型时,在N端添加另一端的主键和联系的属性。

为什么这么映射?
可以减少数据库的冗余,因为如果是把STUDENT的主键添加到STAFF表中,由于一个STAFF可以对应多个学生,这样子就会出现很多冗余的数据

例子:一个班级中有若干名学生,而每个学生只在一个班级中学习,则班级与学生之间具有一对多联系。当转换为关系模式时,我们得在学生关系中添加班级的主键(班级号)。

不需多加实体,多的部分保存在N中

(3)多对多关系(Many to Many)

取关系两端的实体的主键 + 关系本身的属性

当转换为关系模型时,需要将联系转换为实体,然后在该实体上加上另外两个实体的主键,作为联系实体的主键,然后再加上该联系自身带的属性即可。

需要加一个实体保存关系

pic

pic

  1. 四个关系模式:

    商店(商店编号,商店名,地址)

    销售(商店编号商品号,月销售量)

    商品(商品号,商品名,规格,单价)

​ 职工(职工编号,姓名,性别,业绩,商店编号,聘期,月薪)