什么是视图?
视图是⼀个虚拟的表,它是基于⼀个或多个基本表或其他视图的查询结果集。视图本⾝不存储数
据,⽽是通过执⾏查询来动态⽣成数据。⽤⼾可以像操作普通表⼀样使⽤视图进⾏查询、更新和管
理。视图本⾝并不占⽤物理存储空间,它仅仅是⼀个查询的逻辑表⽰,物理上它依赖于基础表中的数据。
创建视图的语法
sql
CREATE VIEW view_name [(column_list)] AS select_statement
视图的优点
- 简化复杂查询:通过将复杂的查询逻辑封装在视图中,可以简化应用程序中的 SQL 编写。
- 提高数据安全性:可以通过视图限制用户访问特定的列或行,而不需要直接访问基础表。
- 数据独立性:如果表结构发生变化,可以通过修改视图来屏蔽这些变化。
- 便于数据分析:视图可以预先定义好数据的汇总、筛选等逻辑,方便分析人员直接使用。
创建一个视图
sql
create view v_student_socre as(
select s.id, s.name, s.sno, s.age, s.gender, s.enroll_date,
c.id as class_id, c.`name` as class_name,
co.id as course_id, co.`name` as course_name, sc.id as score_id, sc.score
from student s, class c, course co, score sc
where s.class_id = c.id
and sc.student_id = s.id
and sc.course_id = co.id
order by s.id
);
访问视图
sql
select * from v_student_socre;
select * from v_student_socre_v1
视图和真实表进行表连接查询
sql
select * from v_student_total_points v, student s where v.id = s.id;
修改视图
通过修改真实表会影响视图,通过视图也可以影响真实表
真实表影响视图
sql
update score set score = 99 where student_id = 1 and course_id = 1;
视图影响基表
sql
update v_student_socre_v1 set score = 99 where score_id = 3;
删除表
语法:
sql
drop view view_name;
注意:
修改真实表会影响视图,修改视图同样也会影响真实表
•
以下视图不可更新:
- 创建视图时使⽤聚合函数的视图
- 创建视图时使⽤ DISTINCT
- 创建视图时使⽤ GROUP BY 以及 HAVING ⼦句
- 创建视图时使⽤ UNION 或 UNION ALL
- 查询列表中使⽤⼦查询
- 在FROM⼦句中引⽤不可更新视图
希望能对大家有所帮助!!!!