首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >MySQL【知识改变命运】12

MySQL【知识改变命运】12

作者头像
用户11319080
发布2024-10-30 08:53:08
发布2024-10-30 08:53:08
1920
举报
文章被收录于专栏:学习学习

1:什么是视图

  • 视图是一张虚拟的表
  • 视图是基于一个或者多个基表或者其他视图查询的结果集
  • 视图本身不占有物理内存,也不存储数据,只是根据查询执行来动态生成数据。
  • 用户对普通表的操作(查询,更新,删除)也可以在视图里面操作。

2:创建视图

代码语言:javascript
复制
# 语法
CREATE VIEW view_name [(column_list)] AS select_statement
create view//创建视图关键词
view_name// 视图名
column_list//视图包含的列
select_statement//视图所依赖的查询语句
  • 我们先查询一下表
  • 然后创建一个视图 这里我们要注意一个小问题,我们要防止在视图中出现名字重复

创建成功:

  • 视图用show tables 查询也在表集合里面
  • 我们可以用视图直接查询
  • 查询视图结构

使用视图(视图的好处)

2.1.隐藏敏感字段

  • 举例:查询⽤⼾的姓名和总分,(隐藏学号和各科成绩
代码语言:javascript
复制
# 使⽤真实表进⾏查询
select s.name, sum(sc.score) total from student s, score sc 
where s.id = sc.student_id
group by sc.student_id order by s.id;

# 如果使⽤真实表,在查询列表中随时可以加上学号字段

# 创建视图
create view v_student_total_points as
select s.id, s.name, sum(sc.score) total from student s, score sc 
where s.id = sc.student_id 
group by s.id order by s.id;
# 使⽤视图查询,只能查到学⽣姓名和总分,不能再添加查询字段

2.2.对外提供统一访问

3:视图和真实表进⾏表连接查询

代码语言:javascript
复制
select * from v_student_total_points v, student s where v.id = s.id;

查询操作,使用视图和使用真实表一样的,有无视图是基于真实表的

4:修改视图数据

4.1:通过真实表修改数据,会影响视图

因为视图本质是依赖于真实表的

4.2:通过视图修改数据会影响基表

但是一下情况,无法使用修改视图

  • 修改真实表会影响视图,修改视图同样也会影响真实表
  • 以下视图不可更新:
  • 创建视图时使⽤聚合函数的视图
  • 创建视图时使⽤ DISTINCT
  • 创建视图时使⽤ GROUP BY 以及 HAVING ⼦句
  • 创建视图时使⽤ UNION 或 UNION ALL
  • 查询列表中使⽤⼦查询
  • 在FROM⼦句中引⽤不可更新视图

6:删除视图

代码语言:javascript
复制
语法:
drop view view_name;
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-10-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1:什么是视图
  • 2:创建视图
  • 使用视图(视图的好处)
    • 2.1.隐藏敏感字段
    • 2.2.对外提供统一访问
    • 3:视图和真实表进⾏表连接查询
  • 4:修改视图数据
    • 4.1:通过真实表修改数据,会影响视图
    • 4.2:通过视图修改数据会影响基表
  • 6:删除视图
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档