软考数据库系统工程师考试真题加答案解析下午试题直接打印.docx
《软考数据库系统工程师考试真题加答案解析下午试题直接打印.docx》由会员分享,可在线阅读,更多相关《软考数据库系统工程师考试真题加答案解析下午试题直接打印.docx(16页珍藏版)》请在冰豆网上搜索。
软考数据库系统工程师考试真题加答案解析下午试题直接打印
中级数据库系统工程师2013上半年下午试题
试题一
阅读以下说明和图,根据要求回答下列问题。
[说明]
某慈善机构欲开发一个募捐系统,以跟踪记录为事业或项目向目标群体进行募捐而组织的集体性活动。
该系统的主要功能如下所示。
1管理志愿者。
根据募捐任务给志愿者发送加入邀请、邀请跟进、工作任务;管理志愿者提供的邀请响应、志愿者信息、工作时长、工作结果等。
2确定募捐需求和收集所募捐赠(资金及物品)。
根据需求提出募捐任务、活动请求和捐赠请求,获取所募集的资金和物品。
3组织募捐活动。
根据活动请求,确定活动时间范围。
根据活动时间,搜索场馆,即:
向场馆发送场馆可用性请求,获得场馆可用性。
然后根据活动时间和地点推广募捐活动,根据相应的活动信息举办活动,从募捐机构获取资金并向其发放赠品。
获取和处理捐赠,根据捐赠请求,提供所募集的捐赠;处理与捐赠人之间的交互,即:
录入捐赠人信息,处理后存入捐赠人信息表;从捐赠人信息表中查询捐赠人信息,向捐赠人发送募捐请求,并将已联系的捐赠人存入已联系的捐赠人表。
根据捐赠请求进行募集,募得捐赠后,将捐赠记录存入捐赠表;对捐赠记录进行处理后,存入已处理捐赠表,向捐赠人发送致谢函。
根据已联系的捐赠人和捐赠记录进行跟进,将捐赠跟进情况发送给捐赠人。
现采用结构化方法对募捐系统进行分析与设计,获得如图所示的分层数据流图。
1、使用说明中的词语,给出图1中的实体E1~E4的名称。
2、在建模DFD时,需要对有些复杂加工(处理)进行进一步精化,图2为图1中处理3的进一步细化的1层数据流图,图3为图2中3.1进一步细化的2层数据流图。
补全图2中加工P1、P2和P3的名称和图2与图3中缺少的数据流。
3、使用说明中的词语,给出图3中的数据存储D1~D4的名称。
试题二
阅读以下说明,根据要求回答下列问题。
[说明]
某航空公司要开发一个订票信息处理系统,该系统的部分关系模式如下:
航班(航班编号,航空公司,起飞地,起飞时间,目的地,到达时间,票价) 折扣(航班编号,开始日期,结束日期,折扣)
旅客(身份证号,姓名,性别,出生日期,电话,VIP折扣) 购票(购票单号,身份证号,航班编号,搭乘日期,购票金额)
有关关系模式的属性及相关说明如下:
4航班表中的起飞时间和到达时间不包含日期,同一航班不会在一天出现两次及两次以上; 5各航空公司会根据旅客出行淡旺季适时调整机票的折扣,旅客购买机票的购票金额计算公式为:
票价×折扣×VIP折扣,其中旅客的VIP折扣与该旅客已购买过的机票的购票金额总和相关,在旅客每次购票后被修改。
VIP折扣值的计算由函数float vip_value(char[18]身份证号)完成。
根据以上描述,回答下列问题。
4、请将如下创建购票关系的SQL语句的空缺部分补充完整,要求指定关系的主键、外键,以及购票金额大于零的约束。
CREATE TABLE 购票(
购票单号 CHAR(15) ______, 身份证号 CHAR(18), 航班编号 CHAR(6), 搭乘日期 DATE,
购票金额 FLOAT ______, ______, ______, );
5、
(1)身份证号为210000************的客户购买了2013年2月18日CA5302航班的机票,购票单号由系统自动生成。
下面的SQL语句将上述购票信息加入系统中,请将空缺部分补充完整。
INSERT INTO 购票(购票单号,身份证号,航班编号,搭乘日期,购票金额)
SELECT '201303105555','210000196006189999','CA5302','2013/2/18', ______
FROM 航班,折扣,旅客
WHERE ______ AND 航班.航班编号='CA5302' AND
AND '2013/2/18' BETWEEN 折扣.开始日期 AND 折扣.结束日期 AND 旅客.身份证号='210000196006189999';
(2)需要用触发器来实现VIP折扣的修改,调用函数vip_value()来实现。
请将如下SQL语句的空缺部分补充完整。
CREATE TRIGGER VIP_TRG AFTER ______ ON ______ RE FERENCING new row AS nrow FOR EACH row BEGIN
UPDATE 旅客 SET ______ WHERE ______; END
6、请将如下SQL语句的空缺部分补充完整。
(1)查询搭乘日期在2012年1月1日至2012年12月31日之间,且合计购票金额大于等于10000元的所有旅客的身份证号、姓名和购票金额总和,并按购票金额总和降序输出。
SELECT 旅客.身份证号,姓名,SUM(购票金额) FROM 旅客,购票 WHERE ______
GROUP BY ______; ORDER BY ______;
(2)经过中转的航班与相同始发地和目的地的直达航班相比,会享受更低的折扣。
查询从广州到北京,经过一次中转的所有航班对,输出广州到中转地的航班编号、中转地、中转地到北京的航班编号。
SELECT ______
FROM 航班航班1,航班 航班2 WHERE ______;
试题三
阅读以下说明,根据要求回答下列问题。
[说明]
某电视台拟开发一套信息管理系统,以方便对全台的员工、栏目、广告和演播厅等进行管理。
[需求分析]
7系统需要维护全台员工的详细信息、栏目信息、广告信息和演播厅信息等。
员工的信息主要包括:
工号、姓名、性别、出生日期、电话和住址等,栏目信息主要包括:
栏目名称、播出时间和时长等。
广告信息主要包括:
广告编号、价格等。
演播厅信息包括:
房间号、房间面积等。
8电视台根据调度单来协调各档栏目、演播厅和场务。
一个销售档栏目只会占用一个演播厅,但会使用多名场务来进行演出协调。
演播厅和场务可以被多个栏目循环使用。
9电视台根据栏目来插播广告。
每档栏目可以插播多条广告,每条广告也可以在多档栏目中插播。
10一档栏目可以有多名主持人,但一名主持人只能主持一档栏目。
11一名编辑人员可以编辑多条广告,一条广告只能由一名编辑人员编辑。
[概念模型设计]
根据需求阶段收集的信息而设计的实体联系图(不完整)如图所示。
[逻辑结构设计]
根据概念模型设计阶段完成的实体联系图,得出如下关系模式(不完整):
演播厅(房间号,房间面积)
栏目(栏目名称,播出时间,时长) 广告(广告编号,销售价格,______)
员工(工号,姓名,性别,出生日期,电话,住址) 主持人(主持人工号,______) 插播单(______,播出时间) 调度单(______)
7、补充图中的联系和联系的类型。
8、根据图,将逻辑结构设计阶段生成的关系模式中补充完整,并用下划线指出所在关系模式的主键。
9、现需要记录广告商信息,增加广告商实体。
一个广告商可以提供多条广告,一条广告只能由一个广告商提供。
请根据该要求,对图进行修改,画出修改后的实体间联系和联系的类型。
试题四
阅读以下说明,根据要求回答下列问题。
[说明]
某水果零售超市拟开发一套信息系统,对超市的顾客、水果、员工、采购和销售信息进行管理。
[需求分析]
10水果零售超市实行会员制,顾客需具有会员资格才能进行购物,顾客需持所在单位出具的证明信才能办理会员资格,每位顾客具有唯一编号。
11超市将采购员和导购员分成若干个小组,每组人员负责指定的若干种水果的采购和导购。
每名采购员可采购指定给该组购买的水果;每名导购员都可对顾客选购的本组内的各种水果进行计价和包装,并分别贴上打印条码。
12顾客选购水果并计价完毕后进行结算,生成结算单。
结算单包括流水号、购买的各种水果信息和顾客信息等,每张结算单具有唯一的流水号。
13超市在月底根据结算单对导购员进行绩效考核,根据采购情况对采购员进行考核,同时也根据结算单对顾客消费情况进行会员积分。
初步设计的数据库关系模式如下。
顾客(顾客编号,身份证号,姓名,性别,积分,单位名称,单位地址,单位电话) 采购(批次,水果名称,采购价格,采购数量,采购员编号) 职责(水果名称,采购员编号,导购员编号)
结算单(流水号,条码,水果名称,销售单价,数量,金额,导购员编号,顾客编号) 数据库关系模式
关系模式的主要属性、含义及约束如表所示。
10、对于“顾客”关系模式,请回答以下问题:
(1)给出所有候选键。
(2)该关系模式可达到第几范式,用60字以内的文字简要叙述理由。
11、对于“结算单”关系模式,请回答以下问题:
(1)用100字以内的文字简要说明它会产生什么问题。
(2)将其分解为第3范式,分解后的关系名依次为:
结算单1,结算单2,结算单3,并用下划线标注分解后的各关系模式的主键。
12、对于“职责”关系模式,请回答以下问题:
(1)它是否为第4范式,用100字以内的文字叙述理由。
(2)将其分解为第4范式,分解后的关系名依次为:
职责1,职责2。
试题五
阅读以下说明,根据要求回答下列问题。
[说明]
某连锁酒店提供网上预订房间业务,流程如下:
13客户查询指定日期内所有类别的空余房间数,系统显示空房表(日期,房间类别,数量)中的信息。
14客户输入预订的起始日期、结束日期、房间类别和数量,并提交。
15系统将用户提交的信息写入预订表(身份证号,起始日期,结束日期,房间类别,数量),并修改空房表的相关数据。
针对上述业务流程,回答下列问题。
13、如果两个用户同时查询相同日期和房间类别的空房数量,得到的空房数量为1,并且这两个用户又同时要求预订,可能会产生什么结果,请用100字以内的文字简要叙述。
14、引入如下伪指令:
将预订过程作为一个事务,将查询和修改空房表的操作分别记为RA.和W(A,x),插入预订表的操作记为W(B,a),其中x代表空余房间数,a代表预订房间数,则事务的伪指令序列为:
x=RA.,W(A,x-a),W(B,a)。
在并发操作的情况下,若客户1、客户2同时预订相同类别的房间时,可能出现的执行序列为:
x1=RA.,x2=RA.,W(A,x1-a1),W(B1,a1),W(A,x2-a2),W(B2,a2)。
(1)此时会出现什么问题,请用100字以内的文字简要叙述。
(2)为了解决上述问题,引入共享锁指令SLock(X)和独占锁指令XLock(X)对数据X进行加锁,解锁指令Unlock(X)对数据X进行解锁,请补充上述执行序列,使其满足2PL协议,不产生死锁且持有锁的时间最短。
15、下面是实现预订业务的程序,请补全空缺处的代码。
其中主变量“:
Cid”、“:
Bdate”、“:
Edate”、“:
Rtype”、“:
Num”分