MySQL:视图

什么是视图?

视图是⼀个虚拟的表,它是基于⼀个或多个基本表或其他视图的查询结果集。视图本⾝不存储数
据,⽽是通过执⾏查询来动态⽣成数据。⽤⼾可以像操作普通表⼀样使⽤视图进⾏查询、更新和管
理。视图本⾝并不占⽤物理存储空间,它仅仅是⼀个查询的逻辑表⽰,物理上它依赖于基础表中的数据。
创建视图的语法

sql 复制代码
CREATE VIEW view_name [(column_list)] AS select_statement

视图的优点

  1. 简化复杂查询:通过将复杂的查询逻辑封装在视图中,可以简化应用程序中的 SQL 编写。
  2. 提高数据安全性:可以通过视图限制用户访问特定的列或行,而不需要直接访问基础表。
  3. 数据独立性:如果表结构发生变化,可以通过修改视图来屏蔽这些变化。
  4. 便于数据分析:视图可以预先定义好数据的汇总、筛选等逻辑,方便分析人员直接使用。

创建一个视图

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⼦句中引⽤不可更新视图

希望能对大家有所帮助!!!!

相关推荐
橘子海全栈攻城狮4 分钟前
【源码+文档+调试讲解】基于Hadoop实现的豆瓣电子图书推荐系统的设计与实现
大数据·数据库·hadoop·spring boot·分布式·后端
NiNg_1_23418 分钟前
Python中Tushare(金融数据库)入门详解
数据库·python·金融
2401_857610031 小时前
实验室管理现代化:Spring Boot技术方案
数据库·spring boot·后端
微微一笑吓死谁1 小时前
linux系统中oracle数据库数据泵导入dmp数据
linux·数据库·oracle
天草二十六_简村人2 小时前
Java语言编程,通过阿里云mongo数据库监控实现数据库的连接池优化
java·jvm·数据库·mongodb·阿里云·微服务·云计算
长风清留扬2 小时前
图文解说:MySQL核心模块知识和流程
大数据·数据库·mysql·面试
highfish9203 小时前
Django实现智能问答助手-数据库方式读取问题和答案
数据库·python·django
jokerest1233 小时前
web——sqliabs靶场——第十二关——(基于错误的双引号 POST 型字符型变形的注入)
数据库·sql·mybatis
尘浮生3 小时前
Java项目实战II基于微信小程序的私家车位共享系统(开发文档+数据库+源码)
java·开发语言·数据库·学习·微信小程序·小程序·maven