【第 1 题】(题型:简答题)
题目:阅读下列说明和图,回答问题 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 的名称。
【问题 2】(4 分)
使用说明中的词语,给出图 1-2 中的数据存储 D1~D4 的名称。
【问题 3】(4 分)
根据说明和图中术语,补充图 1-2 中缺失的数据流及其起点和终点。
【问题 4】(2 分)
用 200 字以内文字,说明建模图 1-1 和图 1-2 时如何保持数据流图平衡。
【 答 案 】【问题 1】
E1:供应商 E2:采购部 E3:检验员 E4:库管员 E5:S/R 职员
【解析】
根据说明中的交互关系:供应商是系统外部实体,接收装运错误通知和缺陷装运通知,对应 E1;采购部门发起检查库存和下达订单操作,对应 E2;检验员执行部件质量检验,对应 E3;库管员负责更新库存,对应 E4;S/R 职员处理装运验证并生成错误通知,对应 E5。
【问题 2】
D1:库存文件 D2:采购订单文件 D3:质量标准文件 D4:供应商文件
【解析】
根据说明中的数据存储描述:检查库存访问的是库存文件(D1);采购订单存储在采购订单文件(D2);检验部件质量访问质量标准文件(D3);下达订单时访问供应商文件(D4)。
【问题 3】
【解析】
根据说明的业务流程:验证装运部件不通过时需向供应商发送装运错误通知;检验部件不通过时需向供应商发送缺陷装运通知;更新库存需要读取原有库存量;验证通过的提单需传递给检验部件质量环节,这些是图 1-2 中缺失的数据流。
【解析】
数据流图平衡是父图与子图的一致性约束,确保数据的输入输出在层级间不丢失、不新增,是结构化分析的核心规则之一。
【第 2 题】(题型:设计题)
题目:阅读下列说明,回答问题 1 至问题 3,将解答填入答题纸的对应栏内。【说明】某房屋租赁公司拟开发一个管理系统用于管理其持有的房屋、租客及员工信息。请根据下述需求描述完成系统的数据库设计。【需求描述】
1. 公司拥有多幢公寓楼,每幢公寓楼有唯一的楼编号和地址。每幢公寓楼中有多套公寓,每套公寓在楼内有唯一的编号(不同公寓楼内的公寓号可相同)。系统需记录每套公寓的卧室数和卫生间数。
2. 员工和租客在系统中有唯一的编号(员工编号和租客编号)。
3. 对于每个租客,系统需记录姓名、多个联系电话、一个银行账号 (方便自动扣房租)、一个紧急联系人的姓名及联系电话。
4. 系统需记录每个员工的姓名、类别、一个联系电话和月工资。员工类别可以经理或维修工,也可兼任。每个经理可以管理多幢公寓楼。每幢公寓楼必须由一个经理管理。系统需记录每个维修工的业务技能,如:水暖维修、电工、木工等。
5. 租客租赁公寓必须和公司签订租赁合同。一份租赁合同通常由一个或多个租客 (合租) 与该公寓楼的经理签订,一个租客也可租赁多套公寓。合同内容应包含签订日期、开始时间租期、押金和月租金。【概念模型设计】根据需求阶段收集的信息,设计的实体联系图 (不完整) 如图 2-1 所示。

【逻辑结构设计】根据概念模型设计阶段完成的实体联系图,得出如下关系模式 (不完整):
联系电话 (电话号码,租客编号)
租客 (租客编号,姓名,银行账号,联系人姓名,联系人电话)
员工 (员工编号,姓名,联系电话,类别,月工资, (a) )
公寓楼 ( (b) ,地址,经理编号)
公寓(楼编号,公寓号,卧室数,卫生间数)
合同(合同编号,租客编号,楼编号,公寓号,经理编号,签订日期,起始日期,租期, (c) ,押金)
【问题 1】(4.5 分)
补充图 2-1 中的 “签约” 联系所关联的实体及联系类型。
【问题 2】(4.5 分)
补充逻辑结构设计中的(a)(b)(c) 三处空缺。
【问题 3】(6 分)
租期内,公寓内设施如出现问题,租客可在系统中进行故障登记,填写故障描述,每项故障由系统自动生成唯一的故障编号,由公司派维修工进行故障维修,系统需记录每次维修的维修日期和维修内容。请根据此需求,对图 2-1 进行补充,并将所补充的 E-R 图内容转换为一个关系模式,请给出该关系模式。
【 答 案 】【问题 1】

【解析】
根据需求:一个租客可签多份合同,一份合同可对应多个租客(合租),故租客与签约是多对多;每个经理可签多份合同,一份合同对应一个经理,故经理与签约是一对多;一份合同对应一套公寓,一套公寓可签多份合同,故公寓与签约是一对多。
【问题 2】
(a)业务技能 (b)楼编号 (c)月租金
【解析】
(a)员工关系中,维修工需要记录业务技能,故补充 “业务技能”;(b)公寓楼的唯一标识是楼编号,作为主键需补充;(c)合同需求中明确包含月租金,故补充 “月租金”。
关系模式:维修记录(故障编号,租客编号(下划虚线),楼编号(下划虚线),公寓号(下划虚线),故障描述,员工编号(下划虚线),维修日期,维修内容)

【解析】
新增故障实体,租客发起故障登记(多对一),维修工处理故障(多对多),维修记录需包含故障基本信息、租客信息、维修工信息及维修详情,故设计对应的关系模式。
【第 3 题】(题型:设计题)
题目:阅读下列说明,回答问题 1 至问题 3,将解答填入答题纸的对应栏内。【说明】某社会救助基金会每年都会举办多项社会公益救助活动,需要建立一个信息系统,对之进行有效管理。【需求描述】
1. 任何一个实名认证的个人或者公益机构都可以发起一项公益救助活动,基金会需要记录发起者的信息。如果发起者是个人,需要记录姓名、身份证号和一部电话号码;如果发起者是公益机构,需要记录机构名称、统一社会信用代码、一部电话号码、唯一的法人代表身份证号和法人代表姓名。一个自然人可以是多个机构的法人代表。
2. 公益救助活动需要提供详实的资料供基金会审核,包括被捐助人姓名、身份证号、一部电话号码、家庭住址。
3. 基金会审核并确认项目后,发起公益救助的个人或机构可以公开宣传并募捐,募捐得到的款项进入基金会账户。
4. 发起公益救助的个人或机构开展救助行动,基金会根据被捐助人所提供的医疗发票或其它信息,直接将所筹款项支付给被捐助者。
5. 救助发起者针对任一被捐助者的公益活动只能开展一次。【逻辑结构设计】根据上述需求,设计出如下关系模式:
公益活动 (发起者编号,被捐助者身份证号,发起者电话号码,发起时间,结束时间,募捐金额),其中对于个人发起者,发起者编号为身份证号;对于机构发起者,发起者编号为统一社会信用代码。
个人发起者(姓名,身份证号,电话号码)
机构发起者 (机构名称,统一社会信用代码,电话号码,法人代表身份证号,法人代表姓名)
被捐助者(姓名,身份证号,电话号码,家庭住址)
【问题 1】(6 分)对关系 “机构发起者”,请回答以下问题:
(1) 列举出所有候选键。
(2) 它是否为 3NF,用 100 字以内文字简要叙述理由。
(3) 将其分解为 BC 范式,分解后的关系名依次为:机构发起者 1,机构发起者 2 ,..., 并用下划线标示分解后的各关系模式的主键。
【问题 2】(6 分)对关系 “公益活动”,请回答以下问题:
(1) 列举出所有候选键。
(2) 它是否为 2NF ,用 100 字以内文字简要叙述理由。
(3) 将其分解为 BC 范式,分解后的关系名依次为:公益活动 1,公益活动 2 ,..., 并用下划线标示分解后的各关系模式的主键。
【问题 3】(3 分)
基金会根据被捐助人提供的医疗发票或其它信息,将所筹款项支付给被捐助者。可以存在分期多次支付的情况,为了统计所筹款项支付情况(详细金额和时间) , 试增加 “支付记录” 关系模式,用 100 字以文字简要叙述解决方案。
【 答 案 】【问题 1】
(1) 候选码:统一社会信用代码
(2) 不是 3NF。存在非主属性 “法人代表姓名” 对候选码 “统一社会信用代码” 的传递函数依赖:统一社会信用代码→法人代表身份证号,法人代表身份证号→法人代表姓名,属于传递依赖。
(3) 机构发起者 1(机构名称,统一社会信用代码,电话号码,法人代表身份证号)
机构发起者 2(法人代表身份证号,法人代表姓名)
【解析】
(1) 统一社会信用代码是机构的唯一标识,可唯一确定机构发起者的所有属性,故为候选键;(2) 3NF 要求消除非主属性对候选键的传递依赖,此处法人代表姓名通过法人代表身份证号传递依赖于统一社会信用代码,不满足 3NF;(3) 分解为两个关系,分别存储机构基本信息和法人代表信息,消除传递依赖,符合 BC 范式。
【问题 2】
(1) 候选码:(发起者编号,被捐助者身份证号)
(2) 不是 2NF。候选码(发起者编号,被捐助者身份证号)部分决定非主属性 “发起者电话号码”,存在部分函数依赖。
(3) 公益活动 1(发起者编号,被捐助者身份证号,发起时间,结束时间,募捐金额)
【解析】
(1) 根据需求,发起者针对同一被捐助者只能发起一次活动,故(发起者编号,被捐助者身份证号)可唯一确定公益活动;(2) 2NF 要求消除非主属性对候选键的部分依赖,发起者电话号码仅由发起者编号决定,属于部分依赖,不满足 2NF;(3) 将发起者电话号码剥离到个人发起者和机构发起者关系中,公益活动关系仅保留与活动直接相关的属性,消除部分依赖。
【问题 3】
新增关系模式:支付记录(发起者编号,被捐助者身份证号,支付时间,金额),其中(发起者编号,被捐助者身份证号,支付时间)为主键,用于记录每笔支付的时间和金额,关联对应的公益活动。
【解析】
支付记录需关联到具体的公益活动(通过发起者编号和被捐助者身份证号),同时记录每次支付的时间和金额,主键需包含三个属性以唯一标识每笔支付记录。
【第 4 题】(题型:SQL 编程题)
题目:阅读下列说明,回答问题 1 至问题 5 ,将解答填入答题纸的对应栏内。【说明】某公司要对其投放的自动售货机建立商品管理系统,其数据库的部分关系模式如下:
售货机:VEM(VEMno, Location) ,各属性分别表示售货机编号、部署地点;
商品: GOODS (Gno, Brand, Price) ,各属性分别表示商品编号、品牌名和价格;
销售单: SALES (Sno, VEMno,Gno,SDate,STime),各属性分别表示销售号、售货机编号、商品编号、日期和时间。
缺货单:OOS (VEMno,Gno,SDate,STime ),各属性分别表示售货机编号、商品编号、 日期和时间。相关关系模式的属性及说明如下:
(1)售货机摆放固定种类的商品,售货机内每种商品最多可以储存 10 件。管理员在每天结束的时候将售货机中所有售出商品补全
(2)每售出一件商品,就自动向销售单中添加一条销售记录。如果一天内某个售货机上某种商品的销售记录达到 10 条,则表明该售货机上该商品已售完,需要通知系统立即补货,通过自动向缺货单中添加一条缺货记录来实现。根据以上描述,回答下列问题,将 SQL 语句的空缺部分补充完整。
【问题 1】(3 分)请将下面创建销售单表的 SQL 语句补充完整,要求指定关系的主码和外码约束。
CREATE TABLE SALES (
Sno CHAR (8) (a)
VEMno CHAR (5) (b)
Gno CHAR (8) (c)
SDate DATE,
STime TIME);
【问题 2】(4 分)创建销售记录详单视图 SALES_Detail ,要求按日期统计每个售货机上各种商品的销售数量,属性有 VEMno、Location 、Gno、Brand 、Price 、amount 和 SDate。为方便实现,首先建立一个视图 SALES_Total ,然后利用 SALES_Total 完成视图 SALES_Detail 的定义。
CREATE VIEW SALES _Total (VEMno, Gno, SDate, amount) AS
SELECT VEMno ,Gno ,SDate ,count (*)
FROM SALES
GROUP BY (d) ;
CREATE VIEW (e) AS
SELECT VEM.VEMno,Location ,GOODS.Gno ,Brand,Price,amount,SDate
FROM VEM,GOODS,SALES_Total
WHERE (f) AND (g) ;
【问题 3】(3 分)每售出一件商品,就自动向销售单中添加一条销售记录。如果一天内某个售货机上某种商品的销售记录达到 10 条,则自动向缺货单中添加一条缺货记录。需要用触发器来实现缺货单的自动维护。程序中的 GetTime()获取当前时间。
CREATE (h) OOS_TRG AFTER (i) ON SALES
REFERENCING new row AS nrow
FOR EACH ROW
BEGIN
INSERT INTO OOS
SELECT SALES .VENno, (j) , GetTime()
FROM SALES
WHERE SALES.VEMno = nrow.VEMno AND SALES.Gno = nrow.Gno AND SALES.SDate = nrow.SDate
GROUP BY SALES.VEMno,SALES.Gno,SALES.SDate
HAVING count()> 0 AND mod(count(), 10)= 0 ;
END
【问题 4】(3 分)查询当天销售最多的商品编号、品牌和数量。程序中的 GetDate ( ) 获取当天日期。
SELECT GOODS.Gno ,Brand, (k)
FROM GOODS, SALES
WHERE GOODS.Gno=SALES.GNO AND SDate =GetDate ( )
GROUP BY (l)
HAVING (m) ( SELECT count (*)
FROM SALES
WHERE SDate = GetDate ( )
GROUP BY Gno );
【问题 5】(2 分)查询一件都没有售出的所有商品编号和品牌。
SELECT Gno ,Brand
FROM GOODS
WHERE Gno (n) (
SELECT DISTINCT Gno
FROM (o) ) ;
【 答 案 】【问题 1】
a) PRIMARY KEY
b) REFERENCES VEM (VEMno)
c) REFERENCES GOODS (Gno)
【解析】
Sno 是销售单的唯一标识,设为主键;VEMno 是售货机表的外键,需引用 VEM 表的 VEMno;Gno 是商品表的外键,需引用 GOODS 表的 Gno。
d) VEMno,Gno,SDate
e) SALES_Detail (VEMno,Location,Gno,Brand,Price,amount,SDate)
f) VEM.VEMno = SALES_Total.VEMno
g) GOODS.Gno=SALES_Total.Gno (f 和 g 可互换)
【解析】
SALES_Total 按售货机、商品、日期分组统计销量;SALES_Detail 需要关联售货机表、商品表和统计视图,获取完整的销售详情。
h) TRIGGER
i) INSERT
j) SALES.Gno, SALES.SDate
【解析】
创建 INSERT 触发器,当销售单插入记录时触发;触发器中统计当天该售货机该商品的销量,当销量是 10 的倍数时插入缺货记录。
k) Count ()
l) GOODS.Gno, Brand
m) Count() >=ALL
【解析】
按商品编号和品牌分组统计当天销量,使用 >=ALL 子查询筛选出销量最大的商品。
n) NOT IN 或 <> ANY
o) SALES
【解析】
使用 NOT IN(或 <> ANY)查询未出现在销售单中的商品,即未售出的商品。
【第 5 题】(题型:事务与并发控制题)
题目:阅读下列说明,回答问题 1 和问题 2 ,将解答填入答题纸的对应栏内。【说明】某抢红包软件规定发红包人可以一次抛出多个红包,由多个人来抢。要求每个抢红包的人最多只能抢到同一批次中的一个红包,且存在多个人同时抢同一红包的情况。给定的红包关系模式如下:
Red (ID,BatchID,SenderID,Money,ReceiverID)
其中 ID 唯一标识每一个红包; BatchID 为发红包的批次,一个 BatchID 值可以对应多个 ID 值;SenderID 为发红包人的标识;Money 为红包中的钱数; ReceiverID 记录抢到红包的人的标识。
发红包人一次抛出多个红包,即向红包表中插入多条记录,每条记录表示一个红包, 其 ReceiverID 值为空值。
抢某个红包时,需要判定该红包记录的 ReceiverID 值是否为空,不为空时表示该红包己被抢走,不能再抢,为空时抢红包人将自己的标识写入到 ReceiverID 宇段中,即为抢到红包。
【问题 1】(9 分)
引入两个伪指令 a = R (X) 和 W (b,X)。其中 a = R (X) 表示读取当前红包记录的 ReceiverID 字段(记为数据项 X)到变量 a 中,W (b,X) 表示将抢红包人的唯一标识 b 的值写入到当前红包记录的 ReceiverID 字段 (数据项 X) 中,变量 a 为空值时才会执行 W (b,X) 操作。假设有多个人同时抢同一红包(即同时对同一记录进行操作),用 ai=Ri (X) 和 Wi (bi,X) 表示系统依次响应的第 i 个人的抢红包操作。假设当前数据项 X 为空值,同时有三个人抢同一红包,则
(1)如下的调度执行序列:
a1 =R1 (X),a2 = R2 (X),W1 (b1,X),W2 (b2,X),a3 = R3 (X)抢到红包的是第几人?并说明理由。
(2)引入共享锁指令 SLocki (X)、独占锁指令 XLocki (X) 和解锁指令 UnLocki (X) ,其中下标 i 表示第 i 个抢红包人的指令。如下的调度执行序列:SLock1 (X),a1 = R1 (X),SLock2 (X),a2 = R2 (X),XLock1 (X)......是否会产生死锁?并说明理由。
(3)为了保证系统第一个响应的抢红包人为最终抢到红包的人,请使用上述 (2) 中引入的锁指令,对上述 (1) 中的调度执行序列进行修改,在满足 2PL 协议的前提下,给出一个不产生死锁的完整的调度执行序列。
【问题 2】(6 分)下面是用 SQL 实现的抢红包程序的一部分,请补全空缺处的代码
CREATE PROCEDURE ScrambleRed (
IN BatchNo VARCHAR (20) , -- 红包批号
IN RecvrNo VARCHAR (20)) -- 接收红包者 ID
BEGIN
-- 是否已抢过此批红包
if exists ( SELECT * FROM Red
WHERE BatchID = BatchNo AND ReceiverID = RecvrNo) then
return -1;
end if;-- 读取此批派发红包中未领取的红包记录 ID
DECLARE NonRecvedNo VARCHAR (30);
DECLARE NonRecvedRed CURSOR FOR
SELECT ID
FROM Red
WHERE BatchID = BatchNo AND ReceiverID IS NULL;-- 打开游标
OPEN NonRecvedRed;
FETCH NonRecvedRed INTO NonRecvedNo;
while not error-- 抢红包事务
BEGIN TRANSACTION;// 写入红包记录
UPDATE Red SET ReceiverID = RecvrNo
WHERE ID = NonRecvedNo AND (a) ;// 执行状态判定
if < 修改的记录数 > = 1 then
COMMIT;
(b) ;
return 1;
else
ROLLBACK;
end if;
(c) ;
end while;-- 关闭游标
CLOSE NonRecvedRed;
return 0;
END
【 答 案 】【问题 1】
(1) 第 2 人。理由:第 1 人读取 X 为空后写入 b1,但第 2 人已提前读取 X 为空,随后写入 b2 覆盖了第 1 人的写入,最终 X 的值为 b2。
(2) 会产生死锁。理由:第 1 人持有 X 的共享锁,申请独占锁时需等待第 2 人释放共享锁;第 2 人持有 X 的共享锁,后续申请独占锁时也需等待第 1 人释放共享锁,双方相互等待形成死锁。
(3) 示例执行序列:XLock1 (X),a1=R1 (X),W1 (b1,X),Unlock1 (X),XLock2 (X),a2=R2 (X),Unlock2 (X),XLock3 (X),a3=R3 (X),Unlock3 (X)(答案不唯一,需满足 2PL 协议,且先申请独占锁的人完成写入)
【解析】
(1) 并发调度中未加锁时,会出现 “丢失更新” 问题,后执行的写入操作会覆盖先执行的写入操作;
(2) 共享锁与独占锁冲突,两个事务都持有共享锁并申请独占锁,会形成循环等待,触发死锁;
(3) 2PL 协议要求事务在加锁阶段申请所有需要的锁,解锁阶段释放所有锁,通过先申请独占锁保证只有第一个事务能写入,避免死锁和丢失更新。
【问题 2】
a) ReceiverID IS NULL
b) CLOSE NonRecvedRed
c) FETCH NonRecvedRed INTO NonRecvedNo
【解析】
(a) UPDATE 语句需增加 ReceiverID IS NULL 的条件,确保只更新未被领取的红包;(b) 抢红包成功后需关闭游标并返回;(c) 抢红包失败时需继续读取下一个未领取的红包。
・数据流图(DFD)的基本元素:实体、加工、数据存储、数据流
・数据流图的平衡规则:父图与子图的输入输出一致性
・结构化分析方法的核心流程梳理
・ER 图的实体、联系及联系类型(一对一、一对多、多对多)
・ER 图向关系模式的转换规则
・关系模式的属性设计与主键约束
・候选键的定义与识别方法
・关系模式的规范化:2NF、3NF、BC 范式的定义与判定
・关系模式分解的原则:保持函数依赖、无损连接
・业务需求到关系模式的转换方法
・SQL 表创建语句:主键、外键约束的定义
・SQL 视图的创建与多表关联查询
・SQL 触发器的创建与触发逻辑
・分组统计与聚合函数的使用
・子查询与集合运算(NOT IN、ALL)
THE END -
点击下方卡片关注我 点个小赞你必上岸↓↓↓

