视图

本文详细介绍了MySQL中的视图功能,包括视图的概念、创建、修改、删除和查看等操作。视图是一种虚拟存在的表,方便重用复杂SQL查询结果,提高数据安全性。通过示例展示了如何创建、修改和查询视图,并讨论了视图更新的条件及与表操作的区别。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1,视图的介绍

视图含义: MySQL从5.0.1版本开始提供视图功能。一种虚拟存在的表,行和列的数据来自定义视图的查询中使用的表。并且是在使用视图时动态生成的,只保存了sql逻辑,不保存查询结果,不占用物理内存

应用场景:
—多个地方用到同样的查询结果
—该查询结果使用的sql语句较复杂

2,视图的创建

语法:

create view 视图名 as 查询语句;

好处:

1:重用sql语句

2:简化复杂的sql操作

3:保护数据,提高安全性

——————————————

演示:在staff表中,运用视图查询小江,小王的姓名,id,和薪水
staff表
在这里插入图片描述
第一步:创建视图

语法:
CREATE VIEW virtualForm AS SELECT * FROM staff WHERE NAME=“小江” OR NAME =“小王”;

第二步:查询视图得到结果

语法:SELECT * FROM virtualForm;
在这里插入图片描述
——————————————————

3,视图的修改

1:create or replace 视图名 as 查询语句;

2:alter view 视图名 as 查询语句;

——————————————————————
演示:在staff表中,运用视图只查询小江的姓名,id,和薪水

第一步:视图修改

语法: ALTER VIEW virtualForm AS SELECT * FROM staff WHERE NAME=“小江”;

第二步:查询视图得到结果

语法:SELECT * FROM virtualForm;

在这里插入图片描述
————————————————————

4,视图的删除

语法:drop view 视图名,视图名;

5,视图的查看

语法:desc 视图名;

演示:查看视图virtualForm

语法: DESC virtualForm;
在这里插入图片描述

6,视图的更新

与DML语言操作效果一样

视图的更新,原始表也会更新

视图和表比较

创建语法是否占用物理空间使用
视图create view 视图名 as只是保存sql逻辑一般不可以增删改查
create table 表名()保存了数据可以增删改查

一般不可以增删改查原因:
具备以下特点的视图不允许更新:
包含以下关键字的mqsql语旬:分组函数、distinct,group by,having,union或者union all常量视,图
Select中包含子查询
join
from一个不能更新的视图
where子句的子查询引用了from子旬中的表

我们还简单视图进行演示插入,修改,删除

——————————————————————————————
演示:创建视图virtualForm,并演示插入,修改,删除

语法:CREATE VIEW virtualForm AS SELECT * FROM staff;
staff表
在这里插入图片描述

virtualForm
在这里插入图片描述

  • 插入
    插入小百,薪水190

语法:INSERT INTO virtualForm (name,salary) VALUES(“小百”,190);

在这里插入图片描述

  • 修改

修改小百薪水为2600

语法:UPDATE virtualForm SET salary=2600 WHERE name=“小百”;

  • 删除小百

删除小百

语法;DELETE FROM virtualForm WHERE name=“小百”;

————————————————————————

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值