试题二阅读以下说明,根据要求回答下列问题。[说明] 某航空公司要开发一个订票信息处理系统,该系统的部分关系模式如下:航班(航班编号,航空公司,起飞地,起飞时间,目的地,到达时间,票价)折扣(航班编号,开始日期,结束日期,折扣)旅客(身份证号,姓名,性别,出生日期,电话,VIP折扣)购票(购票单号,身份证号,航班编号,搭乘日期,购票金额)有关关系模式的属性及相关说明如下:(1)航班表中的起飞时间和到达时间不包含日期,同一航班不会在一天出现两次及两次以上;(2)各航空公司会根据旅客出行淡旺季适时调整机票的折扣,旅客购买机票的购票金额计算公式为:票价×折扣×VIP折扣,其中旅客的VIP折扣与该旅客已购买过的机票的购票金额总和相关,在旅客每次购票后被修改。VIP折扣值的计算由函数float vip_value(char[18]身份证号)完成。根据以上描述,回答下列问题。
(1)身份证号为210000196006189999的客户购买了2013年2月18日CA5302航班的机票,购票单号由系统自动生成。下面的SQL语句将上述购票信息加入系统中,请将空缺部分补充完整。INSERT INTO 购票(购票单号,身份证号,航班编号,搭乘日期,购票金额)SELECT ’201303105555’,’210000196006189999’,’CA5302’,’2013/2/18’,______FROM 航班,折扣,旅客WHERE ______ AND 航班.航班编号=’CA5302’ ANDAND ’2013/2/18’ BETWEEN 折扣.开始日期 AND 折扣.结束日期AND 旅客.身份证号=’210000196006189999’;(2)需要用触发器来实现VIP折扣的修改,调用函数vip_value()来实现。请将如下SQL语句的空缺部分补充完整。CREATE TRIGGER VIP_TRG AFTER ______ ON ______RE FERENCING new row AS nrowFOR EACH rowBEGINUPDATE 旅客SET ______WHERE ______;END
参考答案:票价*折扣*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.身份证号”。