-- 1.参照实验五中完成的查询,按如下要求设计和建立视图: -- (1)基于单个表按投影操作定义视图:创建“教师_view”视图 CREATE VIEW 教师_view AS SELECT 教师编号,姓名 FROM 教师表; -- (2)基于单个表按选择操作定义视图:创建“教师_view_newa”视图 CREATE VIEW 教师_view_newa AS SELECT * FROM 教师表 WHERE 性别 = '男'; -- (3)基于单个表按选择和投影操作定义视图:创建“学生_view1”视图 CREATE VIEW 学生_view1 AS SELECT 学号,姓名 FROM 学生表 WHERE 平均成绩 > 85; -- (4)基于多个表根据连接操作定义视图:创建“学生视图”视图 CREATE VIEW 学生视图 AS SELECT 学生表.*,选课表.课程编号 FROM 学生表 JOIN 选课表 ON 学生表.学号=选课表.学号; -- (5)基于多个表根据嵌套操作定义视图: CREATE VIEW 嵌套操作 AS SELECT * FROM 教师表 WHERE 工资= ANY( SELECT 工资 FROM 教师表 WHERE 工资>4500 ); -- 2.分别在定义的视图设计3种查询(包括基于视图和基本表的一般、连接和嵌套查询) -- (1)基于教师_view的一般查询 SELECT * FROM 教师_view; -- (2)基于学生视图的连接查询 SELECT 学生视图.*,选课表.成绩 FROM 学生视图 JOIN 选课表 ON 学生视图.学号=选课表.学号; -- (3)基于new_view的嵌套查询 -- 3.在定义的视图上分别进行插入、更新和删除操作,分情况讨论哪些操作可以成功完成,哪些操作不能完成,并分析原因。 -- (1)插入操作 INSERT INTO 学生视图(姓名, 学号, 性别, 院系编号, 平均成绩) VALUES ('剑十一', 31, '男', 1, 110); -- (2)更新操作 UPDATE 学生视图 SET 院系编号 = 3 WHERE 学号 = 6; -- (3)删除操作 DELETE FROM 学生视图 WHERE 学号 = 31;