【MySQL数据库】详细讲解MySQL的视图操作

🎄视图介绍

MySQL 视图是指虚拟的表,它本身不存储数据,而是从一个或多个表中获取数据并进行组合和展示。视图看起来像是一个普通的表,可以用于查询、更新和删除数据,但实际上其存储的是一条 SQL 语句,用于定义视图的结构和数据。

🎄视图特点

可以简化查询操作:通过使用视图,我们可以将复杂的 SQL 查询转换为简单的 SELECT 查询。

可以对查询结果进行过滤和加工:我们可以在视图中加入 WHERE 和 GROUP BY 等条件来对查询结果进行过滤和加工,进一步满足特定的查询需求。

可以提高查询效率:如果视图是从多个表中获取数据,并且每次都需要进行复杂的 JOIN 操作,那么使用视图可以避免重复的 JOIN 操作,从而提高查询效率。

可以保护数据安全:通过限制视图的访问权限,我们可以防止用户访问某些敏感数据。

🌺基本操作

⭐创建视图

create [or replace] view 视图名[(列名列表)] as select 语句 ;

sql 复制代码
create or replace view tb_v_1 as select id,name from tb_abc where id>=1;

创建成功后,我们会发现在界面中出现了 视图 这个选项 png)

⭐查询视图

查看创建视图语句

show create view 视图名称;

查看视图数据

select * from 视图名称......;

sql 复制代码
show create view tb_v_1;
sql 复制代码
select * from tb_v_1;

⭐修改视图

方法一

create [or replace] view 视图名称[(列名列表)] as select 语句;

sql 复制代码
create or replace view tb_v_1 as select id,name,money from tb_abc where id>=1;

方法二

alter view 视图名称[(列名列表)] as select 语句;

sql 复制代码
alter view tb_v_1 as select id,name from tb_abc where id>=1;

⭐删除视图

drop view [if exist] 视图名称[视图名称]......;

sql 复制代码
drop view if exist tb_v_1;

⭐向视图中插入数据

sql 复制代码
insert into tb_v_1 values(666,'Tom');

🎄视图的检查选项

MySQL 视图的检查选项是指在创建和修改视图时,可以使用的一些选项来检查视图定义是否正确。以下是常用的视图检查选项:

WITH CHECK OPTION:使用该选项可以确保对视图的更新操作符合视图定义的过滤条件。如果更新操作不符合视图定义的过滤条件,将会被拒绝。

WITH CASCADED CHECK OPTION:类似于 WITH CHECK OPTION,但是会递归地应用到所有依赖于当前视图的其他视图。也就是说,如果更新操作不符合当前视图以及依赖于当前视图的其他视图的过滤条件,更新操作将会被拒绝。

WITH LOCAL CHECK OPTION:类似于 WITH CHECK OPTION,但是只会应用到当前视图,不会递归地应用到依赖视图。也就是说,只有当更新操作不符合当前视图的过滤条件时,才会被拒绝。

默认使用WITH CASCADED CHECK OPTION

🎄视图的更新

视图中的行基础表中的行==必须存在一一对应的关系==

如果视图包含下面任意一项,那么视图不可更新

  • 聚合函数或窗口函数(sum() min() max() count())
  • distinct
  • group by
  • having
  • union
  • union all
相关推荐
半路程序员几秒前
Go内存泄漏排查pprof和trace使用
开发语言·后端·golang
WongLeer2 分钟前
Go + GORM 多级分类实现方案对比:内存建树、循环查询与 Preload
开发语言·后端·mysql·golang·gorm
Victor3568 分钟前
Hibernate(34)Hibernate的别名(Alias)是什么?
后端
superman超哥11 分钟前
Rust HashMap的哈希算法与冲突解决:高性能关联容器的内部机制
开发语言·后端·rust·哈希算法·编程语言·冲突解决·rust hashmap
Victor35614 分钟前
Hibernate(33) Hibernate的投影(Projections)是什么?
后端
a程序小傲15 分钟前
【Node】单线程的Node.js为什么可以实现多线程?
java·数据库·后端·面试·node.js
奋进的芋圆9 小时前
DataSyncManager 详解与 Spring Boot 迁移指南
java·spring boot·后端
计算机程序设计小李同学10 小时前
个人数据管理系统
java·vue.js·spring boot·后端·web安全
Echo娴10 小时前
Spring的开发步骤
java·后端·spring
追逐时光者10 小时前
TIOBE 公布 C# 是 2025 年度编程语言
后端·.net