问答题
(1)身份证号为210000196006189999的客户购买了2013年2月18日CA5302航班的机票,购票单号由系统自动生成。下面的SQL语句将上述购票信息加入系统中,请将空缺部分补充完整。
INSERT INTO 购票(购票单号,身份证号,航班编号,搭乘日期,购票金额)
SELECT '201303105555','210000196006189999','CA5302','2013/2/18',
______
FROM 航班,折扣,旅客
WHERE ______ AND 航班.航班编号='CA5302' AND
AND '2013/2/18' BETWEEN 折扣.开始日期 AND 折扣.结束日期
AND 旅客.身份证号='210000196006189999';
(2)需要用触发器来实现VIP折扣的修改,调用函数vip_value()来实现。请将如下SQL语句的空缺部分补充完整。
CREATE TRIGGER VIP_TRG AFTER ______ ON ______
RE FERENCING new row AS nrow
FOR EACH row
BEGIN
UPDATE 旅客
SET ______
WHERE ______;
END
【答案解析】 (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.身份证号”。
问答题
请将如下SQL语句的空缺部分补充完整。
(1)查询搭乘日期在2012年1月1日至2012年12月31日之间,且合计购票金额大于等于10000元的所有旅客的身份证号、姓名和购票金额总和,并按购票金额总和降序输出。
SELECT 旅客.身份证号,姓名,SUM(购票金额)
FROM 旅客,购票
WHERE ______
GROUP BY ______;
ORDER BY ______;
(2)经过中转的航班与相同始发地和目的地的直达航班相比,会享受更低的折扣。查询从广州到北京,经过一次中转的所有航班对,输出广州到中转地的航班编号、中转地、中转地到北京的航班编号。
SELECT ______
FROM 航班航班1,航班 航班2
WHERE ______;
【正确答案】 身份证号=购票.身份证号 AND
搭乘日期 BETWEEN '2012/1/1' AND '2012/12/31'
旅客.身份证号,姓名 HAVlNG SUM(购票金额)>=10000
SUM(购票金额) DESC
航班1.航班编号,航班1.目的地,航班2.航班编号
航班1.起飞地='广州' AND 航班2.目的地='北京' AND
航班1.目的地=航班2.起飞地;
【答案解析】 (1)查询搭乘日期在2012年1月1日至2012年12月31日之间,且合计购票金额大于等于10000元的所有旅客的身份证号、姓名和购票金额总和,并按购票金额总和降序输出。
SELECT 旅客.身份证号,姓名,SUM(购票金额)
FROM 旅客,购票
WHERE 旅客.身份证号=购票.身份证号 AND
搭乘日期 BETWEEN '2012/1/1' AND '2012/12/31'
GROUP BY 旅客.身份证号,姓名 HAVING SUM(购票金额)>=10000;
ORDER BY SUM(购票金额) DESC;
(2)经过中转的航班与相同始发地和目的地的直达航班相比,会享受更低的折扣。查询从广州到北京,经过一次中转的所有航班对,输出广州到中转地的航班编号、中转地、中转地到北京的航班编号。
SELECT 航班1.航班编号,航班1.目的地,航班2.航班编号
FROM 航班航班1,航班航班2
WHERE 航班1.起飞地='广州' AND 航班2.目的地='北京' AND
航班1.目的地=航班2.起飞地;