2017年上半年 数据库系统工程师 答案详解
2017年上半年 数据库系统工程师 答案详解
2017年上半年 数据库系统工程师 答案详解
基础知识 答案
1、B 2、A 3、D 4、B 5、C
6、A 7、B 8、D 9、B 10、A
11、D 12、D 13、A 14、D 15、16、D B
17、18、A C 19、D 20、A
21、D 22、B 23、C 24、B 25、D
26、C 27、D 28、C 29、B 30、D
31、C 32、D 33、C 34、35、A D
36、37、D C 38、D 39、C 40、41、A D
42、43、44、C D C 45、46、A B
47、C 48、B 49、B 50、D
51、B 52、C 53、D 54、C 55、D
56、B 57、58、A B 59、60、C C
61、B 62、A 63、D 64、65、A D
66、A 67、C 68、B 69、C 70、D
71、72、73、74、75、A A C D C
应用技术 答案
试题一
【问题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】(4.5分)
补充图2-1中的“签约”联系所关联的实体及联系类型。
依据题干中“租客租赁公寓必须和公司签订租赁合同。一份租赁合同通常由一个或多个租客(合租)与该公寓楼的经理签订,一个租客也可租赁多套公寓。合同内容应包含签订日期、开始时间租期、押金和月租金。”,说明签约应该是经理与租赁之间的,而已份租赁包括一位或多位租客,以及一个或多个公寓,所以可以考虑为:经理实体集与租赁(由租客和公寓组合成一个大的实体集)之间的联系
在结合题干中“每个经理管多个公寓楼,每个公寓楼由一个经理管理,和一个楼有多个公寓”的描述,可以判定联系的类型为1:*
【问题2】(4.5分)
补充逻辑结构设计中的( a) (b)(c ) 三处空缺。
(a)业务技能
(b)楼编号
(c)月租金
从题干中“系统需记录每个员工的姓名、类别、一个联系电话和月工资。员工类别可以经理或维修工,也可兼任。每个经理可以管理多幢公寓楼。每幢公寓楼必须由一个经理管理。系统需记录每个维修工的业务技能,如:水暖维修、电工、木工等”说明需要记录的属性有:姓名、类别、一个联系电话、月工资和业务技能。因此(a)处应为:业务技能
题干中“每幢公寓楼有唯一的楼编号和地址以及每幢公寓楼必须由一个经理管理”同时管理联系没有转换成一个独立的关系,也就意味着管理联系被合并到了公寓楼的实体对应的关系中,因此,公寓楼实体对应的关系的属性应该有:楼编号、地址、经理编号;因此(b)处应该为:楼编号
依据题干中“合同内容应包含签订日期、开始时间租期、押金和月租金。”结合关系合同(合同编号,租客编号,楼编号, 公寓号,经理编号,签订日期,起始日期,租期,(c),押金),可以得出(c)处应该为:月租金
【问题3】(6分)
租期内,公寓内设施如出现问题,租客可在系统中进行故障登记,填写故障描述,每项故障由系统自动生成唯一的故障编号,由公司派维修工进行故障维修,系统需记录每次维修的维修日期和维修内容。请根据此需求,对图2-1 进行补充,并将所补充的ER图内容转换为一个关系模式,请给出该关系模式。
维修(故障编号,维修工,维修日期,维修内容,楼编号,公寓号,租客编号)
题干中“租期内,公寓内设施如出现问题,租客可在系统中进行故障登记,填写故障描述,每项故障由系统自动生成唯一的故障编号,由公司派维修工进行故障维修,系统需记录每次维修的维修日期和维修内容”
说明,维修应该与租赁(由租客和公寓组合成一个大的实体集)之间存在多对多的联系,同时需要有自己的属性:故障编号、维修日期、维修内容。
维修(故障编号,维修工,维修日期,维修内容,楼编号,公寓号,租客编号)
试题三
【问题1】(6 分)
对关系"机构发起者",请回答以下问题:
(1) 列举出所有候选键。
(2) 它是否为3NF ,用1100字以内文字简要叙述理由。
(3) 将其分解为 BC 范式,分解后的关系名依次为:机构发起者1,机构发起者 2 ,..., 并用下划线标示分解后的各关系模式的主键。
(1)统一社会信用代码
(2)否,存在传递依赖 :统一社会信用代码→法人代表身份证号,法人代表身份证号→法人代表姓名
(3)机构发起者1(机构名称,统一社会信用代码,电话号码,人代表身份证号)主键:统一社会信用代码
机构发起者2(人代表身份证号,法人代表姓名)主键:法人代表身份证号
【问题2】(6 分)
对关系“公益摇动 ”,请回答以下问题:
(1)列举出所有候选键。
(2) 它是否为2NF ,用100字以内文字简要叙述理由。
(3)将其分解为 BC 范式,分解后的关系名依次为:公益活动1,公益活动 2 ,..., 并用下划线标示分解后的各关系模式的主键。
(1)发起者编号+被捐助者身份证号
(2)否:存在部分函数依赖:发起者编号→(发起者电话号码)对码(发起者编号,被捐助者身份证号)存在部分函数依赖
(3)公益活动1(发起者编号,发起者电话号码)主键:发起者编号
公益活动2(发起者编号,被捐助者身份证号,发起时间,结束时间,募捐金额)主键:发起者编号+被捐助者身份证号
【问题3】(3分)
基金会根据被捐助人提供的医疗发票或其它信息,将所筹款项支付给被捐助者。可以存在分期多次支付的情况,为了统计所筹款项支付情况(详细金额和时间) ,试增加”支付记录“关系模式,用100字以文字简要叙述解决方案。
支付记录(支付编号,发起者编号,被捐助者身份证号,支付金额,支付时间,被捐助人的相关信息)(被捐助人的相关信息为医疗发票或其他信息),支付编号唯一标识每一次支付
试题四
【问题1】(3 分)
请将下面创建销售单表的 SQL 语句补充完整,要求指定关系的主码和外码约束。
CREATE TABLE SALES(
Sno CHAR(8) (a)
VEMno CHAR(5) (b)
Gno CHAR(8) (c)
SDate DATE,
STime TIME);
(a)PRIMARY KEY
(b)REFERENCES VEM(VEMno)
(c)REFERENCES GOODS(Gno)
【问题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 VENno ,Gno ,SDate ,count(*)
FROM SALES
GROUP BY (d);
CREATE VIWE (e) AS
SELECT VEM.VEMno,Location ,GOODS.Gno ,Brand,Price,amount,SDate
FROM VEM,GOODS,SALES_Total
WHERE (f) AND (g)
(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可以互换
【问题3】 (3分)
每售出一件商品,就自动向销售单中添加一条销售记录。如果一天内某个售货机上某种商品的销售记录达到 10条,则自动向缺货单中添加一条缺货记录。需要用触发器来实现缺货单的自动维护。程序中的 GetTime()获取当前时间。
CREAT(h) OOS_TRG AFTER (i) ON SALES
REFERENCING new row AS nrow
FOR EACH ROW
BEGIN
INSERT INTO OOS
SELECT SALES .VENno, (j) GetTime()
FROMSALES
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
(h)TRIGGER
(i)INSERT
(j)SALES.Gno,SALES.SDate
【问题4】 (3分)
查询当天销售最多的商品编号、品牌和数量。程序中的 GetDate()获取当天日期。
SELECT GOODS.Gno ,Brand, (k)
FROM GOODS,SALES
WHERE GOODS.Gno=SALES.GNO AND SDATE =GetDate()
GROUP BY (1)
HAVING(M) (SELECT count(*)
FROM SALELS
WHERE SDATE = GetDate()
GROUP BY Gno);
(k)COUNT(*) AS 数量
(l)GOODS.Gno,Brand
(m)COUNT(*)>=ALL
【问题5】(2分)
查询一件都没有售出的所有商品编号和品牌。
SELECT Gno ,Brand
FROM GOODS
WHERE GNO(N)
SELECT DISTINCT GNO
FROM(o);
(n)NOT IN
(o)SALES
试题五
【问题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, a2 = R2(X),W1(b1 ,X),W2(b2,X), a3 = R3(X)
抢到红包的是第几人?并说明理由。
(2)引入共享锁指令 SLocki(X)、独占锁指令XLocki(X)和解锁指令 ULocki(X) ,其中下标i表示第i个抢红包人的指令。如下的调度执行序列:
SLock1(X),a1 = R1(X),SLock2(X),a2 = R2(X),XLock1(X)......
是否会产生死锁?并说明理由。 (3)为了保证系统第一个响应的抢红包人为最终抢到红包的人,请使用上述。)中引入的锁指令,对上述(1)中的调度执行序列进行修改,在满足2PL协议的前提下,给出一个不产生死锁的完整的调度执行序列。
(1)第2人,并发操作出现了丢失更新的问题,第2个的更新覆盖了第1个的更新,原因是破坏了事物的隔离性。
(2)会产生死锁,由于数据X同时被1和2加锁了S锁,再对方没有释放的时候,都无法加成功X锁,导致1和2一直都处于等待的状态
(3)XLock(X) a=R(X) W(b,X)UNLock(X)
【问题2】(6分)
下面是用 SQL实现的抢红包程序的一部分,请补全空缺处的代码
CREATE PROCEDURE ScrambleRed (IN BatchNo VARCHAR(20) , --红包批号
(IN RecvrNo VARCHAR(20)) 一接收红包者
BEGIN
--是否已抢过此批红包
if exists( SELECT * FROM Red
WHERE BatchID = BatchNo AND ReceiverID = RecvrNo) thm
return -1;
end if;
---读取此批派发红包中未领取的红包记录ID
DECLARE NonRecvedNo VARCHAR(30);
DECLARE NonRecvedNo 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 STE RECDIVER ID =RecvrNo
WHERE ID = nonRECVED AND(a)
//执行状态判定
If<修改的记录数>= 1 THEN
COMMIT;
(b);
Return 1;
Else
ROLLBACK;
End if;
(c);
End while
--关闭游标
CLOSE NonRecved RD
Return 0;
END
(a)BatchID=BatchNo
(b)CLOSE NonRecvedRed
(c)END TRANSACTION
完结