前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >《MySQL核心知识》第11章:视图

《MySQL核心知识》第11章:视图

作者头像
冰河
发布2022-12-01 17:11:40
3600
发布2022-12-01 17:11:40
举报
文章被收录于专栏:冰河技术冰河技术

大家好,我是冰河~~

今天是《MySQL核心知识》专栏的第11章,今天为大家系统的讲讲MySQL中的视图,希望通过本章节的学习,小伙伴们能够举一反三,彻底掌握MySQL中的视图知识。好了,开始今天的正题吧。

为何使用视图?

使用视图的理由是什么?

1、安全性:一般是这样做的:创建一个视图,定义好该视图所操作的数据。

之后将用户权限与视图绑定,这样的方式是使用到了一个特性:grant语句可以针对视图进行授予权限。

2、查询性能提高

3、有灵活性的功能需求后,需要改动表的结构而导致工作量比较大,那么可以使用虚拟表的形式达到少修改的效果。

这是在实际开发中比较有用的

4、复杂的查询需求,可以进行问题分解,然后将创建多个视图获取数据。将视图联合起来就能得到需要的结果了。

创建视图

创建视图的语法

代码语言:javascript
复制
CREATE [OR REPLACE] [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]
    VIEW view_name [(column_list)]
    AS select_statement
    [WITH [CASCADED | LOCAL] CHECK OPTION]

其中,各属性含义如下所示:

  • CREATE:表示新建视图;
  • REPLACE:表示替换已有视图
  • ALGORITHM :表示视图选择算法
  • view_name :视图名
  • column_list:属性列
  • select_statement:表示select语句
  • [WITH [CASCADED | LOCAL] CHECK OPTION]参数表示视图在更新时保证在视图的权限范围之内

可选的ALGORITHM子句是对标准SQL的MySQL扩展。

ALGORITHM可取三个值:MERGE、TEMPTABLE或UNDEFINED。

如果没有ALGORITHM子句,「默认算法是UNDEFINED(未定义的)」。算法会影响MySQL处理视图的方式。

对于MERGE,会将引用视图的语句的文本与视图定义合并起来,使得视图定义的某一部分取代语句的对应部分。对于TEMPTABLE,视图的结果将被置于临时表中,然后使用它执行语句。对于UNDEFINED,MySQL自己选择所要使用的算法。如果可能,它倾向于MERGE而不是TEMPTABLE,这是因为MERGE通常更有效,而且如果使用了临时表,视图是不可更新的。LOCAL和CASCADED为可选参数,决定了检查测试的范围,默认值为CASCADED。视图的数据来自于两个表

代码语言:javascript
复制
CREATE TABLE student (stuno INT ,stuname NVARCHAR(60))
CREATE TABLE stuinfo (stuno INT ,class NVARCHAR(60),city NVARCHAR(60))
INSERT INTO student VALUES(1,'wanglin'),(2,'gaoli'),(3,'zhanghai')
INSERT INTO stuinfo VALUES(1,'wuban','henan'),(2,'liuban','hebei'),(3,'qiban','shandong')
-- 创建视图
CREATE VIEW stu_class(id,NAME,glass) AS SELECT student.`stuno`,student.`stuname`,stuinfo.`class`
FROM student ,stuinfo WHERE student.`stuno`=stuinfo.`stuno`
SELECT * FROM stu_class

查看视图

查看视图必须要有SHOW VIEW权限

查看视图的方法包括:DESCRIBE、SHOW TABLE STATUS、SHOW CREATE VIEW

DESCRIBE查看视图基本信息

代码语言:javascript
复制
DESCRIBE 视图名
DESCRIBE stu_class

结果显示了视图的字段定义、字段的数据类型、是否为空、是否为主/外键、默认值和额外信息

DESCRIBE一般都简写成DESC

SHOW TABLE STATUS语句查看查看视图基本信息

查看视图的信息可以通过SHOW TABLE STATUS的方法

代码语言:javascript
复制
SHOW TABLE STATUS LIKE 'stu_class'

Name       Engine  Version  Row_format    Rows  Avg_row_length  Data_length  Max_data_length  Index_length  Data_free  Auto_increment  Create_time  Update_time  Check_time  Collation  Checksum  Create_options  Comment
---------  ------  -------  ----------  ------  --------------  -----------  ---------------  ------------  ---------  --------------  -----------  -----------  ----------  ---------  --------  --------------  -------
stu_class  (NULL)   (NULL)  (NULL)      (NULL)          (NULL)       (NULL)           (NULL)        (NULL)     (NULL)          (NULL)  (NULL)       (NULL)       (NULL)      (NULL)       (NULL)  (NULL)          VIEW   

COMMENT的值为VIEW说明该表为视图,其他的信息为NULL说明这是一个虚表,如果是基表那么会基表的信息,这是基表和视图的区别

SHOW CREATE VIEW语句查看视图详细信息

代码语言:javascript
复制
SHOW CREATE VIEW stu_class

View Create View                                                                                                                                                                                                character_set_client  collation_connection
---------  ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------  --------------------  --------------------
stu_class  CREATE ALGORITHM=UNDEFINED 
DEFINER=`root`@`localhost` SQL SECURITY DEFINER VIEW `stu_class` AS 
select `student`.`stuno` AS `id`,
`student`.`stuname` AS `name`,
`stuinfo`.`class` AS `class` 
from (`student` join `stuinfo`) 
where (`student`.`stuno` = `stuinfo`.`stuno`)  utf8 utf8_general_ci          

执行结果显示视图的名称、创建视图的语句等信息

在VIEWS表中查看视图的详细信息

在MYSQL中,INFORMATION_SCHEMA VIEWS表存储了关于数据库中的视图的信息

通过对VIEWS表的查询可以查看数据库中所有视图的详细信息

代码语言:javascript
复制
SELECT * FROM `information_schema`.`VIEWS`

TABLE_CATALOG  TABLE_SCHEMA  TABLE_NAME  VIEW_DEFINITION
CHECK_OPTION  IS_UPDATABLE  DEFINER
SECURITY_TYPE  CHARACTER_SET_CLIENT  COLLATION_CONNECTION
-------------  ------------  ----------  --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------  ------------  --------------  -------------  --------------------  --------------------
def            school        stu_class   
select `school`.`student`.`stuno` AS `id`,
`school`.`student`.`stuname` AS `name`,
`school`.`stuinfo`.`class` AS `class` 
from `school`.`student` join `school`.`stuinfo` 
where (`school`.`student`.`stuno` = `school`.`stuinfo`.`stuno`)  
NONE          YES           
root@localhost  DEFINER utf8 utf8_general_ci         

当前实例下只有一个视图stu_class

修改视图

修改视图是指修改数据库中存在的视图,当基本表的某些字段发生变化时,可以通过修改视图来保持与基本表的一致性。

MYSQL中通过CREATE OR REPLACE VIEW 语句和ALTER语句来修改视图

语法如下:

代码语言:javascript
复制
ALTER OR REPLACE [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]
VIEW view_name [(column_list)]
AS select_statement
[WITH [CASCADED | LOCAL] CHECK OPTION]

该语句用于更改已有视图的定义。其语法与CREATE VIEW类似。当视图不存在时创建,存在时进行修改。修改视图

代码语言:javascript
复制
DELIMITER $$

CREATE OR REPLACE VIEW `stu_class` AS 
SELECT
  `student`.`stuno`   AS `id`
FROM (`student` JOIN `stuinfo`)
WHERE (`student`.`stuno` = `stuinfo`.`stuno`)$$

DELIMITER ; 

通过DESC来查看更改之后的视图定义

代码语言:javascript
复制
DESC stu_class;

可以看到只查询一个字段

ALTER语句修改视图

代码语言:javascript
复制
ALTER [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]
VIEW view_name [(column_list)]
AS select_statement
[WITH [CASCADED | LOCAL] CHECK OPTION]

这里关键字跟前面的一样,这里不做介绍

使用ALTER语句修改视图 stu_class

代码语言:javascript
复制
ALTER VIEW  stu_class AS SELECT stuno FROM student;

使用DESC查看

代码语言:javascript
复制
DESC stu_class;

更新视图

更新视图是指通过视图来插入、更新、删除表数据,因为视图是虚表,其中没有数据。

通过视图更新的时候都是转到基表进行更新,如果对视图增加或者删除记录,实际上是对基表增加或删除记录

我们先修改一下视图定义

代码语言:javascript
复制
ALTER VIEW  stu_class AS SELECT stuno,stuname FROM student;

查询视图数据

UPDATE

代码语言:javascript
复制
UPDATE stu_class SET stuname='xiaofang' WHERE stuno=2;

查询视图数据

更新成功

INSERT

代码语言:javascript
复制
INSERT INTO stu_class VALUES(6,'haojie');

插入成功

DELETE

代码语言:javascript
复制
DELETE FROM stu_class WHERE stuno=1;

删除成功

当视图中包含如下内容的时候,视图的更新操作将不能被执行

(1)视图中包含基本中被定义为非空的列

(2)定义视图的SELECT语句后的字段列表中使用了数学表达式

(3)定义视图的SELECT语句后的字段列表中使用聚合函数

(4)定义视图的SELECT语句中使用了DISTINCT、UNION、TOP、GROUP BY 、HAVING子句

删除视图

删除视图使用DROP VIEW语法

代码语言:javascript
复制
DROP VIEW [IF EXISTS]
view_name [, view_name] ...
[RESTRICT | CASCADE]

DROP VIEW能够删除1个或多个视图。必须在每个视图上拥有DROP权限

可以使用关键字IF EXISTS来防止因不存在的视图而出错

删除stu_class视图

代码语言:javascript
复制
DROP VIEW IF EXISTS stu_class

如果名称为 stu_class 的视图存在则删除。使用SHOW CREATE VIEW语句查看结果

代码语言:javascript
复制
SHOW CREATE VIEW stu_class
Query: -- update stu_class set stuname='xiaofang' where stuno=2; 
-- delete from stu_class where stuno=1 -- select * from stu_class; 
-- ... Error Code: 1146 Table 'school.stu_class' doesn't exist 
Execution Time : 0 sec 
Transfer Time : 0 sec 
Total Time : 0.004 sec
---------------------------------------------------

该视图不存在,删除成功。

好了,如果文章对你有点帮助,记得给冰河一键三连哦,欢迎将文章转发给更多的小伙伴,冰河将不胜感激~~

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2022-09-16,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 冰河技术 微信公众号,前往查看

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 为何使用视图?
  • 创建视图
  • 查看视图
  • 修改视图
  • 更新视图
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档