MySQL 视图

1、概念介绍

视图(View)是一种虚拟存在的表。视图中的数据并不在数据库中实际存在,行和列数据来自定义视图的查询中使用的表,并且是在使用视图时动态生成的。

通俗的讲,视图只保存了查询的SQL逻辑,不保存查询结果。所以我们在创建视图的时候,主要的工作就落在创建这条SQL查询语句上。

视图的作用:

  • 简单:视图不仅可以简化用户对数据的理解,也可以简化他们的操作。那些被经常使用的查询可以被定义为视图,从而使得用户不必为以后的操作每次指定全部的条件。
  • 安全:数据库可以授权,但不能授权到数据库特定行和特定的列上。通过视图用户只能查询和修改他们所能见到的数据
  • 数据独立:视图可帮助用户屏蔽真实表结构变化带来的影响。

视图的更新:要使视图可更新,视图中的行与基础表中的行之间必须存在一对一的关系。如果视图包含以下任何一项,则该视图不可更新:

  • 聚合函数或窗口函数(SUM()、MIN()、MAX()、COUNT()等)
  • DISTINCT
  • GROUP BY
  • HAVING
  • UNION或者UNION ALL
2、视图操作
  • 创建视图:CREATE [OR REPLACE] VIEW 视图名称[(列名列表)] AS SELECT 语句 [WITH[CASCADE | LOCAL] CHECK OPTION]
  • 查看创建视图语句: SHOW CREATE VIEW 视图名称
  • 查看视图:SELECT * FROM 视图名称
  • 修改视图:ALTER VIEW 视图名称[(列名列表)] AS SELECT语句 [WITH[CASCADED | LOCAL] CHECK OPTION]
  • 删除视图:DROP VIEW [IF EXISTS] 视图名称
# 创建视图
CREATE OR REPLACE VIEW stu_v_1 AS SELECT * FROM student;

# 查询创建视图语句
SHOW CREATE VIEW stu_v_1;
# 查询视图中的数据
SELECT * FROM stu_v_1;
SELECT * FROM stu_v_1 WHERE id < 3;

# 修改视图
# 方式一
ALTER VIEW stu_v_1 AS SELECT id,`name` FROM student WHERE id > 3;
# 方式二
CREATE OR REPLACE VIEW stu_v_1 AS SELECT id,`name` FROM student;
SELECT * FROM stu_v_1;

# 删除视图
DROP VIEW IF EXISTS stu_v_1 ;
3、检查选项

视图并不保存真实数据,如果向视图中插入一条数据,数据会被插入相关的表中。这就会出现一种情况——因为创建视图时添加了创建条件,所以导致新增的数据使用视图无法查出来(例如:创建视图时,限制了id要小于20;然而却向视图中添加了一个id为30的数据,那么现在查询视图是无法将此数据显示出来)。为了避免这种情况的发生,需要使用检查选项WITH CHECK OPTION

当使用WTH CHECK OPTION子句创建视图时,MySQL会通过视图检查正在更改的每个行,例如插入,更新,删除,以使其符合视图的定义。MySQL允许基于另一个视图创建视图,它还会检查依赖视图中的规则以保持一致性。为了确定检查的范围,mysql提供了两个选项:CASCADED和LOCAL,默认值为CASCADED。

MySQL 视图_第1张图片

a. 级联检查:CASCADED

CASCADED,级联检查:不管基视图(基于视图创建新视图时的已经创建的视图)是否有检查选项,都要对其进行条件检测。

当基于另一个视图,创建新的视图时,指定了检查选项为CASCADED,此时对新视图中的操作必须同时满足“基本视图”和“新视图”的创建条件,才能操作成功。

MySQL 视图_第2张图片

MySQL 视图_第3张图片

b. 自身检查:LOCAL

LOCAL,自身检查:只有当基视图(基于视图创建新视图时的已经创建的视图)自身有检查选项时,才对其进行条件检测。

MySQL 视图_第4张图片

你可能感兴趣的:(MySQL,mysql,数据库)