MySQL数据库视图的作用是什么
从现在开始,我们要努力学习啦!今天我给大家带来《MySQL数据库视图的作用是什么》,感兴趣的朋友请继续看下去吧!下文中的内容我们主要会涉及到等等知识点,如果在阅读本文过程中有遇到不清楚的地方,欢迎留言呀!我们一起讨论,一起学习!
1 视图的介绍与作用
视图的介绍:
视图 view 是一个虚拟表,非真实存在,其 本质是根据SQL语句获取动态的数据集,并为其命名, 用户使用时只需要使用视图名称即可获取结果集,并可以将其当作表来使用。
数据库中只存放了视图的定义,而并没有存放视图中的数据。 数据还存在于原来的数据表中。
使用视图查询数据时,数据库系统会从原来的表中取出对应的数据。因此, 视图中的数据是依赖于原来表中数据的。 当表的数据发生改变,视图中的数据也会随之改变。
视图的作用:
简化代码, 我们可以把重复使用的查询封装成视图重复使用,同时可以 使复杂的查询易于理解;
更加安全, 比如,如果有一张表中有很多数据,很多信息不希望被其他人看到,这时就可以使用到视图,对不同的用户使用不同的视图。
2 视图的创建
创建视图的语法如下:
create [or replace] [algorithm = {undefined | merge | temptable}] view view_name [(column_list)] as select_statement [with [cascaded | local] check option]
参数说明:
algorithm: 表示视图选择的算法,可选;
view_name: 创建的视图名称;
column_list: 指定视图中各个属性的名词,默认情况下与SELECT语句中查询的属性相同;
select_statement: 表示一个完整的查询语句,将查询记录导入视图中;
[with [cascaded | local] check option]: 表示更新视图时要保证该视图在权限范围之内。
3 视图的修改
修改视图是指修改数据库中已存在的表的定义。当基本表中的某些字段发生改变时,可以通过修改视图来保持视图和基本表之间的一致。
语法格式:
alter view 视图名 as select语句;
4 视图的更新
并不是所有的视图都可以更新。可以在UPDATE、DELETE或INSERT等语句中使用视图,以更新基本表的内容。对于可更新的视图,在视图中的行和基本表中的行之间必须具有一对一的关系,如果视图包含下述结构中的任何一种,则该视图不可更新:
聚合函数(SUM()、MIN()、MAX()等);
DISTINCT;
HAVING;
UNION或者UNION ALL;
位于选择列表中的子查询;
JOIN;
FROM子句中的不可更新视图;
WHERE子句中的子查询,引用FROM子句中的表;
仅使用文字值(在该情况下,没有要更新的基本表)。
注意:
视图中虽然可以更新数据,但是有很多限制。一般情况下,最好将视图作为查询数据的虚拟表,而不要通过视图更新数据。
当真实表中修改了某个存在视图中的字段时,视图需要更新,否则该视图就会变成无效视图!
5 视图的重命名与删除
重命名视图:
rename table 视图名 to 新视图名;
删除视图:
drop view if exists 视图名;
删除视图时,只删除了视图的定义,而并不会删除真实表中的数据
如果想同时删除多个视图,则使用下面的语法格式:
drop view if exists 视图名1, 视图名2, 视图名3...;
6 视图的练习
6.1 数据准备
在进行练习时可以先根据下面代码创建用于练习的两个基本表:
create table college( cno int null, cname varchar(20) null);
create table student( sid int null, name varchar(20) null, gender varchar(20) null, age int null, birth date null, address varchar(20) null, score double null);
两表的基本数据如下图所示:
6.2 查询平均分最高的学校名称
结合之前学过的知识可以 尝试使用子查询和连接查询 来实现,参考代码如下:
SELECT cname FROM (SELECT cname, rank() over (order by avg_score desc ) item FROM (SELECT cname, avg(score) avg_score FROM student JOIN college ON sid = cno GROUP BY cname) t) tt WHERE item = 1;
在上述代码中,先将student 与 college两表关联,将关联的查询作为子表,并根据子表进行平均数的排序,平均数序号为1的平均分数最高,再以此为子表进行子查询,查询出了平均分最高的学校。具体结果如下:
这种方式虽然能够解决问题,但是相对复杂,不容易看懂,为了简化代码,我们可以将每一个子查询创建为一个视图
视图解决方式代码:
-- 1 视图一,连接两表并计算平均数 CREATE VIEW t_view AS SELECT cname, avg(score) avg_score FROM student JOIN college ON sid = cno GROUP BY cname; -- 2 视图二,利用视图一对平均分数进行排序标号 CREATE VIEW tt_view AS SELECT cname, rank() over (order by avg_score desc ) item FROM (t_view); -- 3 利用视图查询 SELECT cname FROM (tt_view) WHERE item = 1;
在创建完视图后,如果想要查询平均分前三名学校,则方便很多,创建好的视图可以直接使用!
参考代码及结果:
SELECT cnameFROM (tt_view)WHERE item = 1 OR item = 2 OR item = 3;
理论要掌握,实操不能落!以上关于《MySQL数据库视图的作用是什么》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

- 上一篇
- windows系统mysql压缩包版本安装的方法是什么

- 下一篇
- MySql8如何设置远程连接
-
- 数据库 · MySQL | 12分钟前 |
- 从零学mysql操作,数据库使用攻略
- 188浏览 收藏
-
- 数据库 · MySQL | 39分钟前 | mysql MariaDB innodb myisam MichaelWidenius
- MySQL英文全称及名称起源揭秘
- 126浏览 收藏
-
- 数据库 · MySQL | 49分钟前 |
- MySQL中英文界面切换技巧,轻松上手
- 161浏览 收藏
-
- 数据库 · MySQL | 1小时前 |
- MySQL中英文界面自由切换的实用技巧
- 321浏览 收藏
-
- 数据库 · MySQL | 2小时前 | 索引 表结构 降序排序 DESC SHOWCREATETABLE
- MySQL中desc的用法:降序排序和表结构查看
- 167浏览 收藏
-
- 数据库 · MySQL | 2小时前 | 权限管理 字符集 排序规则 CREATEDATABASE IFNOTEXISTS
- MySQL建库详解:createdatabase命令使用
- 297浏览 收藏
-
- 数据库 · MySQL | 2小时前 |
- MySQL事务详解:特性与作用深度剖析
- 141浏览 收藏
-
- 数据库 · MySQL | 3小时前 |
- MySQL中文版全流程:语言包安装与配置
- 263浏览 收藏
-
- 数据库 · MySQL | 13小时前 |
- MySQLas关键字别名功能详解
- 393浏览 收藏
-
- 数据库 · MySQL | 15小时前 |
- MySQL安装后启动服务及客户端连接方法
- 229浏览 收藏
-
- 数据库 · MySQL | 15小时前 |
- MySQL中文界面设置教程轻松搞定
- 431浏览 收藏
-
- 数据库 · MySQL | 15小时前 |
- MySQL中文界面设置教程:轻松搞定
- 263浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 魔匠AI
- SEO摘要魔匠AI专注于高质量AI学术写作,已稳定运行6年。提供无限改稿、选题优化、大纲生成、多语言支持、真实参考文献、数据图表生成、查重降重等全流程服务,确保论文质量与隐私安全。适用于专科、本科、硕士学生及研究者,满足多语言学术需求。
- 21次使用
-
- PPTFake答辩PPT生成器
- PPTFake答辩PPT生成器,专为答辩准备设计,极致高效生成PPT与自述稿。智能解析内容,提供多样模板,数据可视化,贴心配套服务,灵活自主编辑,降低制作门槛,适用于各类答辩场景。
- 37次使用
-
- Lovart
- SEO摘要探索Lovart AI,这款专注于设计领域的AI智能体,通过多模态模型集成和智能任务拆解,实现全链路设计自动化。无论是品牌全案设计、广告与视频制作,还是文创内容创作,Lovart AI都能满足您的需求,提升设计效率,降低成本。
- 49次使用
-
- 美图AI抠图
- 美图AI抠图,依托CVPR 2024竞赛亚军技术,提供顶尖的图像处理解决方案。适用于证件照、商品、毛发等多场景,支持批量处理,3秒出图,零PS基础也能轻松操作,满足个人与商业需求。
- 46次使用
-
- PetGPT
- SEO摘要PetGPT 是一款基于 Python 和 PyQt 开发的智能桌面宠物程序,集成了 OpenAI 的 GPT 模型,提供上下文感知对话和主动聊天功能。用户可高度自定义宠物的外观和行为,支持插件热更新和二次开发。适用于需要陪伴和效率辅助的办公族、学生及 AI 技术爱好者。
- 45次使用
-
- MySQL主从切换的超详细步骤
- 2023-01-01 501浏览
-
- Mysql-普通索引的 change buffer
- 2023-01-25 501浏览
-
- MySQL高级进阶sql语句总结大全
- 2022-12-31 501浏览
-
- Mysql报错:message from server: * is blocked because of many
- 2023-02-24 501浏览
-
- 腾讯云大佬亲码“redis深度笔记”,不讲一句废话,全是精华
- 2023-02-22 501浏览