ER图概念模型转换为关系模式
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)
取关系两端的实体的主键 + 关系本身的属性
当转换为关系模型时,需要将联系转换为实体,然后在该实体上加上另外两个实体的主键,作为联系实体的主键,然后再加上该联系自身带的属性即可。
需要加一个实体保存关系
-
四个关系模式:
商店(商店编号,商店名,地址)
销售(商店编号,商品号,月销售量)
商品(商品号,商品名,规格,单价)
职工(职工编号,姓名,性别,业绩,商店编号,聘期,月薪)