2017 上半年数据库系统工程师考试真题及答案-下午卷
试题一
阅读下列说明和图,回答问题 1 至问题 4 ,将解答填入答题纸的对应栏内。
【说明】
某医疗器械公司作为复杂医疗产品的集成商,必须保持高质量部件的及时供应。为了实
现这一目标,该公司欲开发一采购系统。系统的主要功能如下:
1.检查库存水平。采购部门每天检查部件库存量,当特定部件的库存量降至其订货店时,
返回低存量部件及库存量。
2.下达采购订单。采购部门针对低存量部件及库存量提交采购请求,向其供应商(通过
供应商文件访问供应商数据)下达采购订单,并存储于采购订单文件中。
3. 交运部件。当供应商提交提单并交运部件时,运输和接收(S /R )部门通过执行以下
三步过程接收货物:
(1)验证装运部件。通过访问采购订单并将其与提单进行比较来验证装运的部件, 并将
提单信息发给 S/R 职员。如果收货部件项目出现在采购订单和提单上,则己验证的提单和
收货部件项目将被送去检验。否则 S /R 职员提交的装运错误信息生成装运错误通知发送给
供应商。
(2) 检验部件质量。通过访问质量标准来检查装运部件的质量,并将己验证的提单发给
检验员。如果部件满足所有质量标准,则将其添加到接受的部件列表用于更新部件库存。如
果部件未通过检查,则将检验员创建的缺陷装运信息生成缺陷装运通知发送给供应商。
(3)更新部件库存。库管员根据收到的接受的部件列表添加本次采购数量,与原有库存
量累加来更新库存部件中的库存量。标记订单采购完成。
现采用结构化方法对该采购系统进行分析与设计,获得如图 1-1 所示的上下文数据流图和
图 1-2 所示的 0 层数据流图。
【问题 1】(5 分)
使用说明中的词语,给出图 1-1 中的实体 E1-E5 的名称。
E1:供应商
E2:采购部
E3:检验员
E4:库管员
E5:S/R 职员
依据题干中“下达采购订单。采购部门针对低存量部件及库存量提交采购请求,向其供应商
(通过供应商文件访问供应商数据)下达采购订单,并存储于采购订单文件中。”可以判断
出 E1 为供应商
依据题干中“检查库存水平。采购部门每天检查部件库存量,当特定部件的库存量降至其订
货店时,返回低存量部件及库存量。”,可以判断出 E2 为采购部
依据题干中“通过访问质量标准来检查装运部件的质量,并将己验证的提单发给检验员。如
果部件满足所有质量标准,则将其添加到接受的部件列表用于更新部件库存。”,可以判断出
E3 为检验员
依据题干中“库管员根据收到的接受的部件列表添加本次采购数量”,可以判断出 E4 为库管
理员
依据题干中“如果收货部件项目出现在采购订单和提单上,则己验证的提单和收货部件项目
将被送去检验。否则 S/R 职员提交的装运错误信息生成装运错误通知发送给供应商。”,可以
判断出 E5 为 S/R 职员
【问题 2】(4 分)
使用说明中的词语,给出图 1-2 中的数据存储 D1-D4 的名称。
D1:库存表
D2:采购订单表
D3:质量标准表
D4:供应商表
依据题干中“更新部件库存。库管员根据收到的接受的部件列表添加本次采购数量,与原有
库存量累加来更新库存部件中的库存量。”,结合零层图的数据流,可以得出 D1 为库存表
依据题干中“下达采购订单。采购部门针对低存量部件及库存量提交采购请求,向其供应商
(通过供应商文件访问供应商数据)下达采购订单,并存储于采购订单文件中。”和“更新
部件库存。库管员根据收到的接受的部件列表添加本次采购数量,与原有库存量累加来更新
库存部件中的库存量。标记订单采购完成”,结合零层图的数据流,可以得出 D2 为采购订单
表,D4 为采购订单表
依据题干中“检验部件质量。通过访问质量标准来检查装运部件的质量,并将己验证的提单
发给检验员。如果部件满足所有质量标准,则将其添加到接受的部件列表用于更新部件库
存。”,结合零层图的数据流,可以得出 D3 为质量标准表
【问题 3】(4 分)
根据说明和图中术语,补充图 1-2 中缺失的数据流及其起点和终点。
装运错误通知:P3(验证装运部件)-----E1(客户)
缺陷装运通知:P4(校验部件质量)-----E1(客户)
产品检验:P3(验证装运部件)------ P4(校验部件质量)
检查库存信息:P1(检查库存水平)-----D1(库存表)
依据题干中“(1)中:否则 S/R 职员提交的装运错误信息生成装运错误通知发送给供应商。”,
结合零层图可以发现缺失数据流:装运错误通知:P3(验证装运部件)-----E1(客户)
依据题干中“(2)中:如果部件未通过检查,则将检验员创建的缺陷装运信息生成缺陷装运
通知发送给供应商。”,结合零层图可以发现缺失数据流:缺陷装运通知:P4(校验部件质量)
-----E1(客户)
依据题干中“(1)中:如果收货部件项目出现在采购订单和提单上,则己验证的提单和收货
部件项目将被送去检验。”,结合零层图可以发现缺失数据流:产品检验:P3(验证装运部件)
------ P4(校验部件质量)
依据题干中“1、检查库存水平。采购部门每天检查部件库存量,当特定部件的库存量降至
其订货店时,返回低存量部件及库存量。”,结合零层图可以发现缺失数据流:检查库存信息:
P1(检查库存水平)-----D1(库存表)
【问题 4】(2 分)
用 200 字以内文字,说明建模图 1-1 和图 1-2 时如何保持数据流图平衡。
父图中某个加工的输入输出数据流必须与其子图的输入输出数据流在数量上和名字上相同。
父图的一个输入(或输出)数据流对应于子图中几个输入(或输出)数据流,而子图中组成
的这些数据流的数据项全体正好是父图中的这一个数据流。
试题二
阅读下列说明,回答问题 1 至问题 3,将解答填入答题纸的对应栏内。
【说明】
某房屋租赁公司拟开发一个管理系统用于管理其持有的房屋、租客及员工信息。请根据
下述需求描述完成系统的数据库设计。
【需求描述】
1.公司拥有多幢公寓楼,每幢公寓楼有唯一的楼编号和地址。每幢公寓楼中有多套公寓,
每套公寓在楼内有唯一的编号(不同公寓楼内的公寓号可相同)。系统需记录每套公寓的卧
室数和卫生间数。
2.员工和租客在系统中有唯一的编号(员主编号和租客编号)。
3.对于每个租客,系统需记录姓名、多个联系电话、一个银行账号(方便自动扣房租)、
一个紧急联系人的姓名及联系电话。
4.系统需记录每个员工的姓名、类别、一个联系电话和月工资。员工类别可以经理或维
修工,也可兼任。每个经理可以管理多幢公寓楼。每幢公寓楼必须由一个经理管理。 系统
需记录每个维修工的业务技能,如:水暖维修、电工、木工等。
5.租客租赁公寓必须和公司签订租赁合同。一份租赁合同通常由一个或多个租客(合租)
与该公寓楼的经理签订,一个租客也可租赁多套公寓。合同内容应包含签订日期、开始时间
租期、押金和月租金。
【概念模型设计】
根据需求阶段收集的信息,设计的实体联系图(不完整)如图 2-1 所示。
【逻辑结构设计】
根据概念模型设计阶段完成的实体联系图,得出如下关系模式(不完整):
联系电话 (电话号码,租客编号)
租客 (租客编号,姓名,银行账号,联系人姓名,联系人电话)
员工 (员工编号,姓名,联系电话,类别,月工资,( a ))
公寓楼 ( (b) ,地址,经理编号)
公寓(楼编号,公寓号,卧室数,卫生间数)
合同(合同编号,租客编号,楼编号,公寓号,经理编号,签订日期,起始日期,租期,(c ),
押金)
【问题 1】(4.5 分)
补充图 2-1 中的“签约”联系所关联的实体及联系类型。
依据题干中“租客租赁公寓必须和公司签订租赁合同。一份租赁合同通常由一个或多个
租客(合租)与该公寓楼的经理签订,一个租客也可租赁多套公寓。合同内容应包含签订日
期、开始时间租期、押金和月租金。”,说明签约应该是经理与租赁之间的,而已份租赁包括
一位或多位租客,以及一个或多个公寓,所以可以考虑为:经理实体集与租赁(由租客和公
寓组合成一个大的实体集)之间的联系
在结合题干中“每个经理管多个公寓楼,每个公寓楼由一个经理管理,和一个楼有多个
公寓”的描述,可以判定联系的类型为 1:*
【问题 2】(4.5 分)
补充逻辑结构设计中的( a) (b)(c ) 三处空缺。
(a)业务技能
(b)楼编号
(c)月租金
从题干中“系统需记录每个员工的姓名、类别、一个联系电话和月工资。员工类别可以经理
或维修工,也可兼任。每个经理可以管理多幢公寓楼。每幢公寓楼必须由一个经理管理。系
统需记录每个维修工的业务技能,如:水暖维修、电工、木工等”说明需要记录的属性有:
姓名、类别、一个联系电话、月工资和业务技能。因此(a)处应为:业务技能
题干中“每幢公寓楼有唯一的楼编号和地址以及每幢公寓楼必须由一个经理管理”同时管理
联系没有转换成一个独立的关系,也就意味着管理联系被合并到了公寓楼的实体对应的关系
中,因此,公寓楼实体对应的关系的属性应该有:楼编号、地址、经理编号;因此(b)处
应该为:楼编号
依据题干中“合同内容应包含签订日期、开始时间租期、押金和月租金。”结合关系合同(合
同编号,租客编号,楼编号, 公寓号,经理编号,签订日期,起始日期,租期,(c),押金),
可以得出(c)处应该为:月租金
【问题 3】(6 分)
租期内,公寓内设施如出现问题,租客可在系统中进行故障登记,填写故障描述,每项
故障由系统自动生成唯一的故障编号,由公司派维修工进行故障维修,系统需记录每次维修
的维修日期和维修内容。请根据此需求,对图 2-1 进行补充,并将所补充的 ER 图内容转换
为一个关系模式,请给出该关系模式。
维修(故障编号,维修工,维修日期,维修内容,楼编号,公寓号,租客编号)
题干中“租期内,公寓内设施如出现问题,租客可在系统中进行故障登记,填写故障描述,
每项故障由系统自动生成唯一的故障编号,由公司派维修工进行故障维修,系统需记录每次
维修的维修日期和维修内容”
说明,维修应该与租赁(由租客和公寓组合成一个大的实体集)之间存在多对多的联系,同
时需要有自己的属性:故障编号、维修日期、维修内容。
维修(故障编号,维修工,维修日期,维修内容,楼编号,公寓号,租客编号)