列表

详情


阅读下列说明,回答问题1至问题3,将解答填入答题纸的对应栏内。
【说明】
某航空公司要开发一个订票信息处理系统,该系统的部分关系模式如下:
航班(航班编号,航空公司,起飞地,起飞时间,目的地,到达时间,票价)
折扣(航班编号,开始日期,结束日期,折扣)
旅客(身份证号,姓名,性别,出生日期,电话,VIP折扣)
购票(购票单号,身份证号,航班编号,搭乘日期,购票金额)
有关关系模式的属性及相关说明如下:
(1)  航班表中的起飞时间和到达时间不包含日期,同一航班不会在一天出现两次及 两次以上;
(2) 各航空公司会根据旅客出行淡旺季适时调整机票的折扣,旅客购买机票的购票金额计算公式为:票价×折扣×VIP折扣,其中旅客的VIP折扣与该旅客已购买过的机票的购票金额总和相关,在旅客每次购票后被修改。VIP折扣值的计算由函数float vip_value(char[18] 身份证号)完成。

【问题1】
请将如下创建购票关系的SQL语句的空缺部分补充完整, 要求指定关系的主键、外键,以及购票金额大于零的约束。
CREATE TABLE 购票(
购票单号 CHAR()(a),
身份证号CHAR(),
航班编号CHAR (),
搭乘日期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
AND ‘2013/2/18’ BETWEEN 折扣.开始日期 AND 折扣.结束日期
    AND  旅客.身份证号=‘210000196006189999’;
(2)需要用触发器来实现VIP折扣的修改,调用函数vip_value()来实现。请将如下SQL语句的空缺部分补充完整。
   CREATE TRIGGER  VIP_TRG  AFTER(g)ON(h)
   REFERENCING  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)PRIMARY KEY
(b)CHECK(购票金额>0)
(c)FOREIGN  KEY (身份证号) REFERENCES 旅客(身份证号)
(d)FOREIGN  KEY (航班编号) REFERENCES 航班(航班编号)
【问题2】
(1)(e)票价*折扣*VIP折扣
(f)航班.航班编号=折扣.航班编号
(2)(g)INSERT
(h)购票
(i)VIP折扣=vip_value(nrow.身份证号)
(j)旅客.身份证号=nrow.身份证号
【问题3】
(1)(k)旅客.身份证号=购票.身份证号  AND 搭乘日期 BETWEEN ‘2012/1/1’ AND ‘2012/12/31’
(l)旅客.身份证号,姓名 HAVING  SUM(购票金额)>=10000
(m)SUM(购票金额) DESC
(2)(n)航班1.航班编号,航班1.目的地,航班2.航班号
(o)航班1.起飞地=‘广州’ AND 航班2.目的地=‘北京’ AND
          航班1.目的地=航班2.起飞地

详细解析:

【问题1】:题干中要求制定主键,外键,以及一个购票金额大于零的约束。说明中购买关系明确指定了主键为购票单号,外键为身份证号(关联到旅客关系的身份证号),航班编号(关联到航班关系的航班编号)。结合创建购票关系的SQL语句,因此在(a)处应该填写主键的定义:PRIMARY KEY ,(b)是对购票金额的约束,对于一个域的自定义约束使用关键字CHECK,具体的表达式为:CHECK(约束条件表达式),(c)、(d)两处是对外键的定义:定义外键使用的关键字是FOREIGN KEY ,具体格式为:FOREIGN KEY 列名 REFERENCE 表名(列名)。
【问题2】:(1)根据题干中插入语句指定的列名和SELECT 语句中查询的列的情况,可以得出(e)处应该填息购票金额。而题干在说明部分(2)中给出了购票金额的计算公式为:票价×折扣×VIP折扣,因此(e)应该填写对应的SQL语句表达式:票价*折扣*VIP折扣;(f)处是要指定查询的条件,根据题干的要求结合WHERE子句后已经列表出的条件,在结合说明中三个关系的情况,可以得出:折扣是通过航班号,开始时间,结束时间从折扣表中查询出来的;VIP折扣是通过身份证号从旅客表中查询出来的,票价可以直接从航班表中查询,因此,在给定的条件表达式中:通过旅客.身份证号可以从旅客关系中唯一获取VIP折扣,通过航班.航班编号可以从航班关系唯一获取票价;但折扣关系中要唯一获取一个折扣,需要通过航班编号,开始日期,和结束日期三项值;而题干中已经给出了开始日期和结束日期,再结合说明中的关系,航班和折扣关系存在联系,且题中已经给出了定位航班编号的条件,因此可以通过将航班关系和折扣关系进行连接后查询出唯一的票价和折扣

【问题2】:(2)根据题干的要求:必须在插入数据后更新用户的VIP折扣,再结合触发器的语法结构,所以(g)应该题写INSERT (h)应填写的对象 购票;UPDATE语句是触发器的执行体,主要是向旅客关系中更新相关的信息:由于VIP折扣是通过vip_value函数来实现的,所以(i)为VIP折扣=vip_value(nrow.身份证号);(j)处为指定更新语句的条件:旅客.身份证号=nrow.身份证号
【问题3】:(1)根据题干要求,WHERE子句中应该指定旅客关系和购票关系的连接条件,以及搭乘日期范围。GROUP BY 子句中应该指定分类的条件,题干要求按照旅客的身份证号对用户进行分类,然后指定其购票的金额要大于10000。ORDER BY子句中应指定按购票金额的降序排列。
【问题3】:(2)根据题干要求,SELECT子句后应指定的列分别是从广州出发的行编号,中转地,和经中转地到北京的航班编号。WHERE子句应该指定的条件是:从广州起飞,到北京,从广州起飞与到北京的航班都需要经过中转地(即从广州起飞的目的地为到北京航班的起飞地)。

上一题