阅读下列说明,回答问题1至问题3,将解答填入答题纸的对应栏内。 【说明】 某航空公司要开发一个订票信息处理系统,该系统的部分关系模式如下: 航班(航班编号,航空公司,起飞地,起飞时间,目的地,到达时间,票价) 折扣(航班编号,开始日期,结束日期,折扣) 旅

admin2014-08-23  23

问题 阅读下列说明,回答问题1至问题3,将解答填入答题纸的对应栏内。
【说明】
某航空公司要开发一个订票信息处理系统,该系统的部分关系模式如下:
航班(航班编号,航空公司,起飞地,起飞时间,目的地,到达时间,票价)
折扣(航班编号,开始日期,结束日期,折扣)
旅客(身份证号,姓名,性别,出生日期,电话,VIP折扣)
购票(购票单号,身份证号,航班编号,搭乘日期,购票金额)
有关关系模式的属性及相关说明如下:
(1)航班表中的起飞时间和到达时间不包含日期,同一航班不会在一天出现两次及两次以上;
(2)各航空公司会根据旅客出行淡旺季适时调整机票的折扣,旅客购买机票的购票金额计算公式为:票价×折扣×VIP折扣,其中旅客的VIP折扣与该旅客已购买过的机票的购票金额总和相关,在旅客每次购票后被修改。VIP折扣值的计算由函数floatvip一value(char[18]身份证号)完成。根据以上描述,回答下列问题。
(1)身份证号为210000196006189999的客户购买了2013年2月18日CA5302航班的机票,购票单号由系统自动生成。下面的SQL语句将上述购票信息加入系统中,请将空缺部分补充完整。
LSERT INTO购票(购票单号,身份证号,航班编号,搭乘日期,购票金额)
SEt,ECT  ‘201303105555’,‘210000196006189999’,‘CA5302’,‘2013/2/18’,(c)
FROM航班,折扣,旅客
WH:ERE (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 newrowAS nrow
FOR EACH row
BEGIN
UPDATE旅客
SET(i)
WHERE(i);
END

选项

答案(1)(e)票价*折扣*VIP折扣 (f)航班.航班编号=折扣.航班编号 (2)(g)INSERT (h)购票 (i)VIP折扣=vip value(nrow 身份证号) (j)旅客.身份证号-nrow.身份证号

解析 (1)本问题考查INSERT语句的使用。可以将查询结果集插入到基本表中,本题要求完成的包括购票金额的计算表达式和子查询中的条件部分。
(2)本问题考查触发器的定义。需补充的部分涉及到触发器所在的表、触发动作(INSERT/UPDATE/DELETE)及执行代码部分。触发器应由购票表中的INSERT指令所触发,执行代码中要修改的是旅客表中的VIP折扣值,应根据购票表中的新记录,找出对应的旅客表的记录(身份证号相等)进行修改。
转载请注明原文地址:https://kaotiyun.com/show/QuUZ777K
0

相关试题推荐
最新回复(0)