当前位置: 首页icon 软考首页 >考试科目 >2013年5月 数据库系统工程师 下午题之二

2013年5月 数据库系统工程师 下午题之二

作者:wx62e89cc5e381d2023-10-25 01:00:11
备考咨询 刷题指导
添加专属学姐
下载资料 2024上半年软考备考资料+考试大纲
下载按钮 下载
引号

摘要:对于【数据库系统工程师】软考考试而言,真题无疑是最重要的学习资料之一。在软考备考过程中,吃透真题、掌握真题所考知识点、熟悉真题的出题思路,对我们提升分数的效果是最明显的,通过对真题的反复练习,还可以查漏补缺。今天,给大家带来【2013年5月 数据库系统工程师 下午题】部分真题的详解,一起来看看吧~1、阅读下列说明,回答问题1 至问题3 ,将解答填入答题纸的对应栏内。【说

引号
摘要:对于【数据库系统工程师】软考考试而言,试题无疑是最重要的学习资料之一。在软考备考过程中,吃透试题、掌握试题所考知识点、熟悉试题的出题思路,对我们提升分数的效果是最明显的,通过对试题的反复练习,还可以查漏补缺。今天,给大家带来【2013年5月 数据库系统工程师 下午题】部分试题的详解,一起来看看吧~



1、阅读下列说明,回答问题1 至问题3 ,将解答填入答题纸的对应栏内。【说明】某航空公司要开发一个订票信息处理系统,该系统的部分关系模式如下:    航班(航班编号,航空公司,起飞地,起飞时间,目的地,到达时间,票价)    折扣(航班编号,开始日期,结束日期,折扣)    旅客(身份证号,姓名,性别,出生日期,电话,VIP折扣)    购票(购票单号,身份证号,航班编号,搭乘日期,购票金额)    有关关系模式的属性及相关说明如下:(1)航班表中的起飞时间和到达时间不包含日期,同一航班不会在一天出现两次及两次以上;(2)各航空公司会根据旅客出行淡旺季适时调整机票的折扣,旅客购买机票的购票金额计算公式为:票价×折扣×VIP折扣,其中旅客的VIP折扣与该旅客已购买过的机票的购票金额总和相关,在旅客每次购票后被修改。VIP折扣值的计算由函数float vip_value(char[18]身份证号)完成。根据以上描述,回答下列问题。 【问题1】请将如下创建购票关系的SQL语句的空缺部分补充完整,要求指定关系的主键、外键,以及购票金额大于零的约束。    CREATE TABLE 购票(    购票单号 CHAR(15) ___(a)___,    身份证号 CHAR(18),    航班编号 CHAR(6),    搭乘日期 DATE,    购票金额 FLOAT __(b)__,    ___(c)__,    ___(d)__,    );【问题2】(1)身份证号为210000196006189999的客户购买了2013年2月18日CA5302航班的机票,购票单号由系统自动生成。下面的SQL语句将上述购票信息加入系统中,请将空缺部分补充完整。INSERT INTO 购票(购票单号,身份证号,航班编号,搭乘日期,购票金额)    SELECT '201303105555','210000196006189999','CA5302','2013/2/18',    __(e)__    FROM 航班,折扣,旅客    WHERE __(f)__ AND 航班.航班编号='CA5302'    AND '2013/2/18' BETWEEN 折扣.开始日期 AND 折扣.结束日期    AND 旅客.身份证号='210000196006189999';(2)需要用触发器来实现VIP折扣的修改,调用函数vip_value()来实现。请将如下SQL语句的空缺部分补充完整。    CREATE TRIGGER VIP_TRG AFTER ___(g)___ ON ___(h)___    RE FERENCING new  row AS  nrow    FOR EACH row    BEGIN        UPDATE 旅客        SET ___(i)___        WHERE ___(j)___;END【问题3】请将如下SQL语句的空缺部分补充完整。(1)查询搭乘日期在2012年1月1日至2012年12月31日之间,且合计购票金额大于等于10000元的所有旅客的身份证号、姓名和购票金额总和,并按购票金额总和降序输出。    SELECT 旅客.身份证号,姓名,SUM(购票金额)    FROM 旅客,购票    WHERE ___(k)___    GROUP BY ___(l)___;    ORDER BY ___(m)___;(2)经过中转的航班与相同始发地和目的地的直达航班相比,会享受更低的折扣。查询从广州到北京,经过一次中转的所有航班对,输出广州到中转地的航班编号、中转地、中转地到北京的航班编号。    SELECT ___(n)___    FROM 航班航班1,航班 航班2    WHERE ___(o)___;
答案:

【问题1】

(a) PRIMARYKEY (或NOT NULL UNIQUE)

(b) CHECK (购票金额> 0)

(c) FOREIGN KEY (身份证号) REFERENCES 旅客(身份证号)

(d) FOREIGN KEY (航班编号) REFERENCES 航班(航班编号)

【问题2】

(e)票价*折扣*VIP折扣

(f)航班.航班编号=折扣.航班编号

(g) INSERT

(h)购票

(i) VIP折扣= vip _ value(nrow.身份证号)

(j)旅客.身份证号= nrow.身份证号

【问题3】

(k)身份证号=购票.身份证号 AND 搭乘日期 BETWEEN '2012/1/1' AND '2012/12/31'

(l)旅客.身份证号,姓名 HAVlNG SUM(购票金额)>=10000

(m)SUM(购票金额) DESC

(n)航班1.航班编号,航班1.目的地,航班2.航班编号

(o)航班1.起飞地='广州' AND 航班2.目的地='北京' AND  航班1.目的地=航班2.起飞地;



答题解析:

1、 PRIMARY KEY(或NOT NULL UNIQUE)

CHECK(购票金额>0)

FOREIGN KEY (身份证号) REFERENCES 旅客(身份证号)

FOREIGN KEY (航班编号) REFERENCES 航班(航班编号)

在创建"购票"关系模式的SQL语句时,由于属性"购票单号"为"购票"关系模式的主键,即不能为空且唯一标识一条数据记录,因此空缺处需要填入"PRIMARY KEY(或NOT NULL UNIQUE,或NOT NULL PRIMARY KEY)"对该属性进行主键约束。

结合题干给出的关键信息"购票金额大于零"可知,空缺处应填入"CHECK(购票金额>0)"对属性"购票金额"进行约束。

由于属性"身份证号"、"航班编号"是"购票"关系模式的外键,因此空缺处需要使用FOREIGN KEY对这两个属性进行外键约束,即应填入"FOREIGN KEY(身份证号)REFERENCES旅客(身份证号)"、"FOREIGN KEY(航班编号)REFERENCES航班(航班编号)"。

2、 票价*折扣*VIP折扣

航班.航班编号=折扣.航班编号

INSERT

购票

VIP折扣=vip_value(nrow.身份证号)

旅客.身份证号=nrow.身份证号

(1)基于题干给出的关键信息"旅客购买机票的购票金额计算公式为:票价×折扣×VIP折扣"可知,(空缺处对应填入INSERT INTO语句中"购票金额"的计算公式,即"票价*折扣*VIP折扣"。

结合题干给出的"其中旅客的VIP折扣与该旅客已购买过的机票的购票金额总和相关,在旅客每次购票后被修改"等关键信息可知,该SELECT查询语句中将涉及到"航班"、"折扣"两个关系模式,因此空缺处应对这二者进行关联,即应填入"航班.航班编号=折扣.航班编号"。

(2)使用T-SQL语句来创建触发器的基本语句如下。

create trigger trigger_name on {table_name | view_name} {for | After | Instead of}

[insert,update,delete] as sql_statement

在"购票"关系模式中插入一条数据记录时,触发器应能够自动执行,因此需要创建基于INSERT类型的触发器,即空缺处应依次填入"INSERT"、"购票"。

根据题干给出的"VIP折扣值的计算由函数float vip_value(char[18]身份证号)完成"等关键信息可知,空缺处应填入的触发器执行动作是"VIP折扣=vip_value(nrow.身份证号)"。

空缺处应添加表的连接条件--"旅客.身份证号=nrow.身份证号"。

3、旅客.身份证号=购票.身份证号 AND

搭乘日期 BETWEEN '2012/1/1' AND '2012/12/31'

旅客.身份证号,姓名 HAVING SUM(购票金额)>=10000

SUM(购票金额) DESC

航班1.航班编号,航班1.目的地,航班2.航班编号

航班1.起飞地='广州' AND 航班2.目的地='北京' AND

航班1.目的地=航班2.起飞地;

(1)(1)查询搭乘日期在2012年1月1日至2012年12月31日之间,且合计购票金额大于等于10000元的所有旅客的身份证号、姓名和购票金额总和,并按购票金额总和降序输出。

SELECT 旅客.身份证号,姓名,SUM(购票金额)

FROM 旅客,购票

WHERE 旅客.身份证号=购票.身份证号 AND

搭乘日期 BETWEEN '2012/1/1' AND '2012/12/31'

GROUP BY 旅客.身份证号,姓名 HAVING SUM(购票金额)>=10000;

ORDER BY SUM(购票金额) DESC;

(2)经过中转的航班与相同始发地和目的地的直达航班相比,会享受更低的折扣。查询从广州到北京,经过一次中转的所有航班对,输出广州到中转地的航班编号、中转地、中转地到北京的航班编号。

SELECT 航班1.航班编号,航班1.目的地,航班2.航班编号

FROM 航班航班1,航班航班2

WHERE 航班1.起飞地='广州' AND 航班2.目的地='北京' AND

航班1.目的地=航班2.起飞地;



查看完整试题>>>


代理合作学习群