软考143-下午题-【试题二】:E-R图、关系模式

2024-05-09 03:44

本文主要是介绍软考143-下午题-【试题二】:E-R图、关系模式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、分值与目标

15分,目标10+

二、题目形式

示例:

三、E-R图的基本图形元素

示例:

3-1、实体

1、弱实体

在现实世界中有一种特殊的联系,这种联系代表实体间的所有 (Ownership) 关系,例如:职工与家属的联系,家属总是属于某职工的。这种实体对于另一些实体具有很强的依赖关系,即:一个实体的存在必须以另一个实体为前提,将这类实体称为弱实体。

示例:

2、子实体

示例:

职员实体是飞行员、机械师和管理员实体的超类,超类和子类之间具有继承关系。

子类和父类之间的连线用o标识。

3-2、属性

19道历年真题,只有1道E-R图中有属性,其余18道都没有属性。

(1) 简单属性和复合属性。

        简单属性是原子的、不可再分的,复合属性可以细分为更小的部分(即划分为别的属性)。有时用户希望访问整个属性,有时希望访问属性的某个成分,那么在模式设计时可采用复合属性。例如,职工实体集的通信地址可以进一步分为邮编、省、市、街道。若不特别声明,通常指的是简单属性。

(2) 单值属性和多值属性。

        在前面所举的例子中,定义的属性对于一个特定的实体都只有单独的一个值。例如,对于一个特定的职工,只对应一个职工号、职工姓名,这样的属性称为单值属性。但是,在某些特定情况下,一个属性可能对应一组值。例如,职工可能有 0 个、1个或多人亲属,那么职工的亲属的姓名可能有多个数日,这样的属性称为多值属性。

(3) NULL 属性。

        当实体在某个属性上没有值或属性值未知时,使用 NULL 值,表示无意义或不知道。

(4) 派生属性。

        派生属性可以从其他属性得来。例如,职工实体集中有“参加工作时间”和“工作年限”属性,那么“工作年限”的值可以由当前时间和参加工作时间得到。这里,“工作年限”就是一个派生属性。

E-R图中,属性下有下划线的话,该属性是主键!

3-3、联系

1、两个实体之间的联系

2、三个实体之间的联系

两个以上不同实体集之间存在1:1:1、1:1:n、1:m:n、r:m:n的联系。

示例:

设计思虑:

将三个实体之间的关系,拆成两两之间的联系。

四、问题一:补充E-R图中缺失的联系

示例:

4-1、真题

真题1:

注意:

联系名称合理即可。

真题2:

真题3:

五、关系模式和主键、外键

关系模式的格式:

关系名(属性名1,属性名2,......,属性名n)

候选码 (或候选键 ) : 属性或属性组合,其值能够唯一标识一个元组。

主码(或主键): 在一个关系中可能有多个候选码,从中选择一个作为主码。

下午题,一般只有一个候选码,此时,候选码即主键。

属性下面有下划线,即,主键。

示例:

外码(或外键): 如果一个关系中的属性或属性组并非该关系的码,但它们是另外一个关系的码,则称其为该关系的外码。

属性下面有下划虚线,即,外键。

一般,需求分析中会之间将主键告知。

六、E-R图——>关系模式

6-1、实体向关系模式的转换

将 E-R 图中的实体逐一转换成为一个关系模式,实体名对应关系模式的名称,实体的属性转换成关系模式的属性,实体标识符就是关系的码(键)。

6-2、两个实体的联系向关系模式的转换

E-R 图中的2个实体的联系有3 种:

  • 一对一联系(1:1);
  • 一对多联系 (1:n);
  • 多对多联系 (m:n)。

针对这 3 种不同的联系,转换方法如下:

1、一对一联系的转换

一对一联系有两种方式向关系模式进行转换。

一种方式是将联系转换成一个独立的关系模式,关系模式的名称取联系的名称,关系模式的属性包括该联系所关联的两个实体的码及联系的属性,关系的码取自任一方实体的码

另一种方式是将联系归并到关联的两个实体的任一方,给待归并的一方实体属性集中增加另一方实体的码和该联系的属性即可,归并后的实体码保持不变。

示例:


2、一对多联系的转换

一对多联系有两种方式向关系模式进行转换。

一种方式是将联系转换成一个独立的关系模式,关系模式的名称取联系的名称,关系模式的属性取该联系所关联的两个实体的码及联系的属性,关系的码是多方实体的码;

另一种方式是将联系归并到关联的两个实体的多方,给待归并的多方实体属性集中增加一方实体的码和该联系的属性即可,归并后的多方实体码保持不变。

示例:

3、多对多联系的转换

多对多联系只能转换成一个独立的关系模式,关系模式的名称取联系的名称,关系模式的属性取该联系所关联的两个多方实体的码及联系的属性,关系的码是多方实体的码构成的属性组

示例:

6-3、三个实体的联系向关系模式的转换

1、多对多对多联系的转换(n:m:p)

多对多联系只能转换成一个独立的关系模式,关系模式的名称取联系的名称,关系模式的属性取该联系所关联的三个多方实体的码及联系的属性,关系的码是多方实体的码构成的属性组

示例:

1、一对多对多联系的转换(n:m:p)

6-4、超类和子实体的转换

子实体,可转可不转。

示例1:子实体不转为关系模式

示例2:子实体转关系模式

七、问题二

7-1、补充关系模式中的空缺

一个空可能缺失多个属性

在E-R中找不到,要去需求分析结果中查找。

缺失的属性可能是另一个关系模式的主键,要从E-R图中找对应的联系。

7-2、给出几个关系模式的主键、外键

主键,画实线;外键,画虚线。

示例:

7-3、真题

真题1:

安排承运这个关系模式,是安排承运这个联系的转化(一对多),其中的业务员可以看做是员工实体的主键(员工号)

答案格式:

真题2:

答案格式:

注意:

此题中,“配给”并是不对应一个实体,而是一个多对多的联系,单独出来的关系模式。

多对多的联系,单独出来的关系模式,主键:两个实体主键的组合:(商品号、业务员),但是说明中:一个业务员可以负责多个商品的配送,一个商品可以由多个业务员配送,也就是说(商品号、业务员)此时不能唯一确定“配送”关系模式,所以,“配送”关系模式的主键要再加上配送时间!

真题3:

​​​​​​​

答案格式:

这篇关于软考143-下午题-【试题二】:E-R图、关系模式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/972296

相关文章

2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题

题库来源:安全生产模拟考试一点通公众号小程序 2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题是由安全生产模拟考试一点通提供,流动式起重机司机证模拟考试题库是根据流动式起重机司机最新版教材,流动式起重机司机大纲整理而成(含2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题参考答案和部分工种参考解析),掌握本资料和学校方法,考试容易。流动式起重机司机考试技

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

软考系统规划与管理师考试证书含金量高吗?

2024年软考系统规划与管理师考试报名时间节点: 报名时间:2024年上半年软考将于3月中旬陆续开始报名 考试时间:上半年5月25日到28日,下半年11月9日到12日 分数线:所有科目成绩均须达到45分以上(包括45分)方可通过考试 成绩查询:可在“中国计算机技术职业资格网”上查询软考成绩 出成绩时间:预计在11月左右 证书领取时间:一般在考试成绩公布后3~4个月,各地领取时间有所不同

POJ1269 判断2条直线的位置关系

题目大意:给两个点能够确定一条直线,题目给出两条直线(由4个点确定),要求判断出这两条直线的关系:平行,同线,相交。如果相交还要求出交点坐标。 解题思路: 先判断两条直线p1p2, q1q2是否共线, 如果不是,再判断 直线 是否平行, 如果还不是, 则两直线相交。  判断共线:  p1p2q1 共线 且 p1p2q2 共线 ,共线用叉乘为 0  来判断,  判断 平行:  p1p

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚:

CSP 2023 提高级第一轮 CSP-S 2023初试题 完善程序第二题解析 未完

一、题目阅读 (最大值之和)给定整数序列 a0,⋯,an−1,求该序列所有非空连续子序列的最大值之和。上述参数满足 1≤n≤105 和 1≤ai≤108。 一个序列的非空连续子序列可以用两个下标 ll 和 rr(其中0≤l≤r<n0≤l≤r<n)表示,对应的序列为 al,al+1,⋯,ar​。两个非空连续子序列不同,当且仅当下标不同。 例如,当原序列为 [1,2,1,2] 时,要计算子序列 [

模版方法模式template method

学习笔记,原文链接 https://refactoringguru.cn/design-patterns/template-method 超类中定义了一个算法的框架, 允许子类在不修改结构的情况下重写算法的特定步骤。 上层接口有默认实现的方法和子类需要自己实现的方法

【软考】希尔排序算法分析

目录 1. c代码2. 运行截图3. 运行解析 1. c代码 #include <stdio.h>#include <stdlib.h> void shellSort(int data[], int n){// 划分的数组,例如8个数则为[4, 2, 1]int *delta;int k;// i控制delta的轮次int i;// 临时变量,换值int temp;in

【iOS】MVC模式

MVC模式 MVC模式MVC模式demo MVC模式 MVC模式全称为model(模型)view(视图)controller(控制器),他分为三个不同的层分别负责不同的职责。 View:该层用于存放视图,该层中我们可以对页面及控件进行布局。Model:模型一般都拥有很好的可复用性,在该层中,我们可以统一管理一些数据。Controlller:该层充当一个CPU的功能,即该应用程序