用看的、听的学真题

study by eyes and ears.

  1. 首页
  2. 数据库系统工程师
  3. 2013年05月数据库系统工程师考试下午真题【应用技术】
  4. 真题详解

2013年05月数据库系统工程师考试下午真题【应用技术】(第2题) 收藏

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

问题1 (4.0分)

  请将如下创建购票关系的SQL语句的空缺部分补充完整,要求指定关系的主键、外键,以及购票金额大于零的约束。
  CREATE TABLE 购票(
  购票单号 CHAR(15) (a)
  身份证号 CHAR(18)
  航班编号 CHAR(6)
  搭乘日期 DATE,
  购票金额 FLOAT (b)
  (c)
  (d)
  );
暂无

问题2 (6.0分)

  (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)
  RE FERENCING new  row AS  nrow
  FOR EACH row
  BEGIN
  UPDATE 旅客
  SET (i)
  WHERE (j)
  END
暂无

问题3 (5.0分)

  请将如下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
暂无
广告位