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

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

相关推荐
睡不醒男孩0308234 小时前
第二篇:深入探索开源数据库高可用:构建基于CLup的PostgreSQL生产级高可用与读写分离架构
数据库·postgresql·开源·clup
Micro麦可乐6 小时前
Spring Boot 实战:从零设计一个短链系统(含完整代码与数据库设计)
数据库·spring boot·后端·哈希算法·雪花算法·短链系统
码农阿豪6 小时前
从零到一:Spring Boot快速接入金仓数据库实战
数据库·spring boot·后端
鼎讯信通7 小时前
风电光缆运维提质增效:G-4000A 光缆故障追踪仪破解风场巡检难题
运维·网络·数据库
三十..7 小时前
MySQL 从入门到高可用架构实战精要
运维·数据库·mysql
cfm_29148 小时前
Redis五大基本数据结构底层了解
数据结构·数据库·redis
真实的菜9 小时前
Redis 从入门到精通(十二):典型业务场景实战 —— 排行榜、限流器、秒杀系统、Session 共享
数据库·redis·python
你想考研啊9 小时前
mysql数据库导出导入
数据库·mysql·oracle
十年编程老舅10 小时前
Linux DRM:底层逻辑与实践架构
数据库·mysql
The Sheep 202310 小时前
Vue复习
linux·服务器·数据库