某航空公司要开发一个订票信息处理系统,该系统的部分关系模式如下: 航班(航班编

最全题库2022-08-02  60

问题 某航空公司要开发一个订票信息处理系统,该系统的部分关系模式如下:航班(航班编号,航空公司,起飞地,起飞时间,目的地,到达时间,票价)折扣(航班编号,开始日期,结束曰期,折扣)旅客(身份证号,姓名,性别,出生日期,电话,VIP折扣)购票(购票单号,身份证号,航班编号,搭乘日期,购票金额)有关关系模式的属性及相关说明如下:(1)  航班表中的起飞时间和到达时间不包含日期,同一航班不会在一天出现两次及 两次以上;(2) 各航空公司会根据旅客出行淡旺季适时调整机票的折扣,旅客购买机票的购票金额计算公式为:票价X折扣X 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’ ANDAND ‘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  rowBEGIN    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,航班  航班2WHERE(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.起飞地
转载请注明原文地址:https://tihaiku.com/congyezige/2419717.html

最新回复(0)