MySQL 视图

本文介绍了SQL视图的概念,包括其作为虚拟表的特性、作用(简化查询、安全性和数据独立性),并详细讲解了如何创建、查看、修改和删除视图,以及检查选项(CASCADED和LOCAL)在确保视图数据一致性的应用。
摘要由CSDN通过智能技术生成
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。

a. 级联检查:CASCADED

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

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

b. 自身检查:LOCAL

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值