【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
相关推荐
Hello.Reader4 小时前
深入浅出 Rust 的强大 match 表达式
开发语言·后端·rust
customer087 小时前
【开源免费】基于SpringBoot+Vue.JS体育馆管理系统(JAVA毕业设计)
java·vue.js·spring boot·后端·开源
计算机-秋大田10 小时前
基于微信小程序的电子竞技信息交流平台设计与实现(LW+源码+讲解)
spring boot·后端·微信小程序·小程序·课程设计
加油,旭杏12 小时前
【go语言】接口
开发语言·后端·golang
谢大旭12 小时前
ASP.NET Core 中间件
后端·中间件·c#
customer0813 小时前
【开源免费】基于SpringBoot+Vue.JS景区民宿预约系统(JAVA毕业设计)
java·vue.js·spring boot·后端·开源
uzong13 小时前
Java函数式接口:代码艺术的诗意绽放
后端
HelloDam14 小时前
基于 mzt-biz-log 实现接口调用日志记录
后端
SomeB1oody15 小时前
【Rust自学】15.6. RefCell与内部可变性:“摆脱”安全性限制
开发语言·后端·rust