50 lines
1.8 KiB
SQL
50 lines
1.8 KiB
SQL
-- 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;
|