E-R图向关系模型的转换遵循原则

E-R图向关系模型的转换一般遵循如下原则:
1. 一个实体型转换为一个关系模式。实体的属性就是关系的属性。实体的码就是关系的码。
例如在我们的例子中,学生实体可以转换为如下关系模式,其中学号为学生关系的码:
学生(学号,姓名,出生日期,所在系,年级,平均成绩) 同样,性别、宿舍、班级、档案材料、教师、课程、教室、教科书都分别转换为一个关系模式。
2. 一个联系转化为一个关系模式,与该联系相连的各实体的码以及联系的属性转化为关系的属性,该关系的码则有三种情况:
l 若联系为1:1,则每个实体的码均是该关系的后选码。
l 若联系为1:n,则关系的码为n端实体的码。
l 若联系为m:n,则关系的码为诸实体码的组合。

2.1 联系为1:1
一个1:1联系可以转换为一个独立的关系模式,也可以与任意一端对应的关系模式合并。
l 如果转换为一个独立的关系模式,则与该联系相连的各实体的码以及联系本身的属性均转换为关系的属性,每个实体的码均是该关系的候选码。
l 如果与某一端对应的关系模式合并,则需要在该关系模式的属性中加入另一个关系模式的码和联系本身的属性。
例如在我们的例子中,“管理”联系为1:1联系,我们可以将其转换为一个独立的关系模式:
管理(职工号,班级号)或 管理(职工号,班级号)
管理”联系也可以与班级或教师关系模式合并。如果与班级关系模式合并,则只需在班级关系中加入教师关系的码,即职工号:
班级:{班级号,学生人数,职工号}
同样,如果与教师关系模式合并,则只需在教师关系中加入班级关系的码,即班级号:
教师:{职工号,姓名,性别,职称,班级号,是否为优秀班主任}

2.2 联系为1:n
一个1:n联系可以转换为一个独立的关系模式,也可以与n端对应的关系模式合并。
l 如果转换为一个独立的关系模式,则与该联系相连的各实体的码以及联系本身的属性均转换为关系的属性,而关系的码为n端实体的码。
l 如果与n端对应的关系模式合并,则在n端实体对应模式中加入1端实体所对应关系模式的码,以及联系本身的属性。而关系的码为n端实体的码。
例如在我们的例子中,“组成”联系为1:n联系,将其转换为关系模式。
一种方法是使其成为一个独立的关系模式:
组成(学号,班级号)
其中学号为“组成”关系的码。

另一种方法是将其学生关系模式合并,这时学生关系模式为:
学生(学号,姓名,出生日期,所在系,年级,班级号,平均成绩)
后一种方法可以减少系统中的关系个数,一般情况下更倾向于采用这种方法。
2.3 联系为m:n
一个m:n联系转换为一个关系模式。与该联系相连的各实体的码以及联系本身的属性均转换为关系的属性。而关系的码为各实体码的组合。
例如在我们的例子中,“选修”联系是一个m:n联系,可以将它转换为如下关系模式,其中学号与课程号为关系的组合码:
选修(学号,课程号,成绩)
三个或三个以上实体间的一个多元联系转换为一个关系模式。与该多元联系相连的各实体的码以及联系本身的属性均转换为关系的属性。而关系的码为各实体码的组合。
例如在我们的例子中,“讲授”联系是一个三元联系,可以将它转换为如下关系模式,其中课程号、教师号和书号为关系的组合码:
讲授(课程号,教师号,书号)
3.同一实体集的实体间的联系,即自联系,也可按上述1:1、1:n和m:n三种情况分别处理。
例如,如果教师实体集内部存在领导与被领导的1:n自联系,我们可以将该联系与教师实体合并,这时主码职工号将多次出现,但作用不同,可用不同的属性名加以区分,比如在合并后的关系模式中,主码仍为职工号,再增设一个“系主任”属性,存放相应系主任的职工号。
4.具有相同码的关系模式可合并。
为了减少系统中的关系个数,如果两个关系模式具有相同的主码,可以考虑将他们合并为一个关系模式。合并方法是将其中一个关系模式的全部属性加入到另一个关系模式中,然后去掉其中的同义属性(可能同名也可能不同名),并适当调整属性的次序。
例如我们有一个“拥有”关系模式: 拥有(学号,性别)
有一个学生关系模式: 学生(学号,姓名,出生日期,所在系,年级,班级号,平均成绩)
这两个关系模式都以学号为码,我们可以将它们合并为一个关系模式,假设合并后的关系模式仍叫学生:
学生(学号,姓名,性别,出生日期,所在系,年级,班级号,平均成绩)

按照上述4条原则,学生管理子系统中的18个实体和联系可以转换为下列关系模型:
学生(学号,姓名,性别,出生日期,所在系,年级,班级号,平均成绩,档案号)
性别(性别,宿舍楼)
宿舍(宿舍编号,地址,性别,人数)
班级(班级号,学生人数)
教师(职工号,姓名,性别,职称,班级号,是否为优秀班主任)
教学(职工号,学号)
课程(课程号,课程名,学分,教室号)
选修(学号,课程号,成绩)
教科书(书号,书名,价钱)
教室(教室编号,地址,容量)
讲授(课程号,教师号,书号)
档案材料(档案号,……)
该关系模型由12个关系模式组成。其中学生关系模式包含了“拥有”联系、“组成”联系、“归档”联系所对应的关系模式;教师关系模式包含了“管理”联系所对应的关系模式;宿舍关系模式包含了“住宿”联系所对应的关系模式;课程关系模式包含了“开设”联系所对应的关系模式。

 
  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 将E-R模型转换关系模型转换原则包括以下几点: 1. 实体转换关系模型中的表格(即关系),每个实体对应一个表格,表格中的每一行代表一个实体,每一列代表实体的一个属性。 2. 实体属性转换为表格中的列,每个实体属性对应一个列。 3. 实体之间的关系转换为表格之间的关系,即外键。如果一个实体与另一个实体存在一对多的关系,就将多的一方的主键作为少的一方的外键。 4. 将实体之间的多对多关系转换为新的表格,该表格包含这两个实体的主键作为外键。 5. 实体的主键成为表格的主键。如果实体没有主键,就需要创建一个唯一的标识符作为主键。 6. 对于弱实体,它的主键由强实体和一个标识符组成,标识符可以是一个计数器、时间戳或随机数。 7. 对于继承关系,将所有实体属性放在一个表格中,并将子实体的主键作为父实体的外键。 ### 回答2: 将E-R模型转换关系模型转换原则有以下几点: 1. 实体转换E-R模型中的实体集对应关系模型中的表,每个实体的属性对应表的列。关系模型中的每一行代表E-R模型中的一个实体。 2. 属性转换E-R模型中的属性对应关系模型中表的列,属性的值对应表中每个实体的属性值。 3. 主键转换E-R模型中实体的主键对应关系模型中表的主键,用于唯一标识每条数据。通常关系模型的主键是关系模型中一个或多个列的组合。 4. 关系转换E-R模型中的关系对应关系模型中的表,关系中的外键对应关系模型中表的外键。外键用于建立不同表之间的联系,保证数据的一致性和完整性。 5. 多对多关系转换E-R模型中的多对多关系需要通过引入新的关系模型将其转换关系模型。这个新的关系模型中的主键由原关系模型中的两个实体模型的主键组成,用于建立两个实体模型之间的联系。 通过以上原则,可以将E-R模型转换关系模型,从而实现数据的逻辑建模和数据库的设计。这样的设计有助于实现数据的组织、存储和查询,提高数据库的性能和效率。同时,关系模型还可以使用关系代数和关系演算进行数据的操作和处理。 ### 回答3: 将E-R模型转换关系模型转换原则主要有以下几个步骤: 1. 实体转换E-R模型中的实体集转换关系模型中的表,实体集的每一个属性对应为关系模型中的表的列。如果有实体集之间的联系,需要考虑如何存储这些联系。 2. 属性转换E-R模型中的属性转换关系模型中的表的列。属性分为简单属性和复合属性,对应的关系模型中也是将其转换为相应的列。对于多值属性,需要考虑如何处理,可以转换为一个新的表来存储。 3. 关系转换E-R模型中的关系集可以转换关系模型中的外键约束。每一个关系集对应为一个表,其中包含关系的主键和外键。外键引用的另一个表的主键。 4. 主键和外键转换关系模型中的主键和外键是表示实体之间的联系的重要标志。将E-R模型中的实体集和关系集分别转换关系模型的表,然后根据实体集和关系集之间的联系,确定主键和外键之间的对应关系。 5. 范围转换E-R模型中的关系集的范围可以转换关系模型中的数据类型。例如,数值型、字符型、日期型等。 以上是将E-R模型转换关系模型的基本原则转换原则的具体操作可以根据具体的需求和数据库管理系统的要求进行调整。转换过程需要考虑的因素很多,例如数据完整性、范式要求等,确保转换后的关系模型能够满足数据的存储和查询需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值