MySQL进阶篇之视图(view)

news2024/11/26 22:42:32

04、视图/存储过程/触发器

4.1、视图(view)

4.1.1、简介及基本语法

1、介绍

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

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

2、语法

  • 创建

    CREATE [OR REPLACE] VIEW 视图名称[(列名列表)] AS SELECT语句 [WITH [CASCADED | LOCAL] CHECK OPTION]
    
  • 查询

    ## 查看创建视图语句
    SHOW CREATE VIEW 视图名称;
    
    ## 查看视图语句
    SELECT * from 视图名称 ……;
    
  • 修改

    ## 方法一
    CREATE [OR REPLACE] VIEW 视图名称[(列名列表)] AS SELECT语句 [WITH [CASCADED | LOCAL] CHECK OPTION]
    
    ## 方法二
    ALTER VIEW 视图名称[(列名列表)] AS SELECT语句 [WITH [CASCADED | LOCAL] CHECK OPTION]
    
  • 删除

    DROP VIEW [IF EXISTS] 视图名称 [,视图名称]...
    

3、演示

-- 创建视图
create or replace view stu_view_1 as select id,name from student where id <= 10;

-- 查询视图
show create view stu_view_1;            -- 查看视图stu_view_1的创建语句
select * from stu_view_1;               -- 查看stu_view_1视图数据
select * from stu_view_1 where id = 3;  -- 通过设置条件id=3来查看stu_view_1视图数据

-- 修改视图
create or replace view stu_view_1 as select id,name,no from student where id <= 10;

alter view stu_view_1 as select id,name from student where id <= 10;

-- 删除视图
drop view if exists stu_view_1;

4.1.2、检查选项

4.1.2.1、简介

1、案例

-- 创建视图
create or replace view stu_view_1 as select id,name from student where id <= 20;

-- 查看stu_view_1视图数据
select * from stu_view_1;

-- 向视图中插入两条数据
insert into stu_view_1 values (6,'小昭'); -- view中的数据并不在数据库中实际存在,因此插入的数据存放在student表中
insert into stu_view_1 values (30,'张无忌'); 

其中,第一条数据插入到student表中,并且查看stu_view_1视图数据,能够查到该条数据;

第二条数据同样能够插入到student表中,但是查看stu_view_1视图数据,不能够查到该条数据,这是因为在创建view的时候通过where限制了查询条件id<=20,于是这条数据插入到student之后,view中也不会显示,因为该数据不符合视图创建的查询语句。

针对第二条数据的问题,于是在创建视图时使用检查选项

## 下述语句二选一
create or replace view stu_view_1 as select id,name from student where id <= 20 with cascaded check option;
create or replace view stu_view_1 as select id,name from student where id <= 20 with local check option;

需要先将student中插入的两条数据删除,再重新执行上述两条插入语句:

其中,第一条数据插入到student表中,并且查看stu_view_1视图数据,能够查到该条数据;

第二条数据插入时,报错:CHECK OPTION failed 'itcast.stu_view_1'

2、视图的检查选项

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

4.1.2.2、CASCADED

1、CASCADED

在这里插入图片描述

  • v1视图创建时没有使用级联(cascaded)检查选项

    此时对v1进行更改,由于v1创建视图时未使用检查选项,则不需要检查是否满足id<=20的条件。

  • v2基于v1视图进行创建,并且使用级联(cascaded)检查选项

    此时对v2进行更改,由于v2创建视图时使用了检查选项,需要先检查是否满足id>=10的条件;

    然后由于v2是基于v1创建的,且使用的是级联(cascaded)检查选项,则还需要检查是否满足v1的条件,即检查是否满足id<=20的条件。

  • v3基于v2视图进行创建,没有使用级联级联(cascaded)检查选项

    此时对v3进行更改,由于v3创建视图时未使用检查选项,则不需要检查id<=15的查询条件;

    由于v3是基于v2创建的,且v2创建视图时使用了检查选项,则需要检查是否满足id>=10的条件;

    然后由于v2是基于v1创建的,且使用的是级联(cascaded)检查选项,则还需要检查是否满足v1的条件,即检查是否满足id<=20的条件。

2、案例:

-- cascaded
-- 创建stu_view_1视图
create or replace view stu_view_1 as select id,name from student where id <= 20;

-- 向stu_view_1视图中插入数据
insert into stu_view_1 values (5,'赵敏');-- 能够插入到student表中
insert into stu_view_1 values (25,'周芷若');-- 能够插入到student表中

解释:

  • 第一条插入数据:由于创建stu_view_1时没有使用检查选项,所以不需要检查5是否满足stu_view_1的查询条件,则5能够插入到student表中
  • 第二条插入数据:由于创建stu_view_1时没有使用检查选项,所以不需要检查25是否满足stu_view_1的查询条件,则25能够插入到student表中
-- 创建stu_view_2视图(基于stu_view_1视图)
create or replace view stu_view_2 as select id,name from stu_view_1 where id >= 10 with cascaded check option;

-- 向视图stu_view_2中插入数据
insert into stu_view_2 values (7,'Tom');    -- 不能够插入到student表中,不满足stu_view_2查询条件;
insert into stu_view_2 values (26,'周芷若'); -- 不能插入到student表中,满足stu_view_2的条件,不满足tu_view_1的条件
insert into stu_view_2 values (15,'Tom');   -- 能够插入到student表中,满足stu_view_2,stu_view_1的查询条件;

解释:

  • 第一条插入数据:由于stu_view_2创建视图时,使用了级联检查选项,首先需要检查7是否满足stu_view_2的查询条件,因为7<=10,并不符合stu_view_2的查询条件,因此7不能够插入到student表中
  • 第二条插入数据:由于stu_view_2创建视图时,使用了级联检查选项,首先需要检查26是否满足stu_view_2的查询条件,因为26>=10,符合stu_view_2的查询条件;然后由于stu_view_2是基于stu_view_1创建的,且根据级联检查选项的要求,需要检查26是否满足stu_view_1的查询条件,因为26>=20,并不符合stu_view_1的查询条件,因此26不能够插入到student表中
  • 第三条插入数据:由于stu_view_2创建视图时,使用了级联检查选项,首先需要检查15是否满足stu_view_2的查询条件,因为15>=10,符合stu_view_2的查询条件;然后由于stu_view_2是基于stu_view_1创建的,且根据级联检查选项的要求,需要检查26是否满足stu_view_1的查询条件,因为15<=20,符合stu_view_1的查询条件,因此15能够插入到student表中
-- 创建stu_view_3视图(基于stu_view_2视图)
create or replace view stu_view_3 as select id,name from stu_view_2 where id <= 15;

-- 向视图stu_view_3中插入数据
insert into stu_view_3 values (11,'Tom');  -- 能够插入到student表中,满足stu_view_2,stu_view_1的条件 
insert into stu_view_3 values (17,'Tom');  -- 能够插入到student表中,满足stu_view_2,stu_view_1的查询条件;
insert into stu_view_3 values (28,'Tom');  -- 不能够插入到student表中,不满足stu_view_1的条件

解释:

  • 第一条插入数据:由于stu_view_3创建时没有使用检查选项,因此不需要检查stu_view_3的查询条件;由于stu_view_3是基于stu_view_2创建的,需要检查stu_view_2的查询条件,根据stu_view_2使用的级联检查选项,同样需要检查stu_view_1的查询条件;11均满足stu_view_2和stu_view_1的检查条件,因此11能够插入到student表中
  • 第二条插入数据:由于stu_view_3创建时没有使用检查选项,因此不需要检查stu_view_3的查询条件;由于stu_view_3是基于stu_view_2创建的,需要检查stu_view_2的查询条件,根据stu_view_2使用的级联检查选项,同样需要检查stu_view_1的查询条件;17均满足stu_view_2和stu_view_1的检查条件,因此17能够插入到student表中
  • 第三条插入数据:由于stu_view_3创建时没有使用检查选项,因此不需要检查stu_view_3的查询条件;由于stu_view_3是基于stu_view_2创建的,需要检查stu_view_2的查询条件,根据stu_view_2使用的级联检查选项,同样需要检查stu_view_1的查询条件;28满足stu_view_2的查询条件,但是不满足stu_view_1的检查条件,因此28不能够插入到student表中

上述无法插入数据时,报错:CHECK OPTION failed '数据库名.视图名'

如:CHECK OPTION failed 'itcast.stu_view_3'

4.1.2.3、LOCAL

1、LOCAL

在这里插入图片描述

  • v1视图创建时没有使用级联(local)检查选项

    此时对v1进行更改,由于v1创建视图时未使用检查选项,则不需要检查是否满足id<=20的条件。

  • v2基于v1视图进行创建,并且使用级联(local)检查选项

    此时对v2进行更改,由于v2创建视图时使用了检查选项,需要先检查是否满足id>=10的条件;

    然后由于v2是基于v1创建的,则需要递归到v1,但是由于v2使用的是local检查选项,且v1没有检查选项,则不需要检查是否满足v1的条件。

  • v3基于v2视图进行创建,没有使用级联级联(local)检查选项

    此时对v3进行更改,由于v3创建视图时未使用检查选项,则不需要检查id<=15的查询条件;

    由于v3是基于v2创建的,且v2创建视图时使用了检查选项,则需要检查是否满足id>=10的条件;

    然后由于v2是基于v1创建的,则需要递归到v1,但是由于v2使用的是local检查选项,且v1没有检查选项,则不需要检查是否满足v1的条件。

2、案例:

  • 案例1

    -- local
    -- 创建stu_view_4视图
    create or replace view stu_view_4 as select id,name from student where id <= 15;
    
    -- 向stu_view_4视图中插入数据
    insert into stu_view_4 values (5,'Tom'); -- 能够插入到student表中
    insert into stu_view_4 values (16,'Tom');-- 能够插入到student表中
    

    解释:

    • 第一条插入数据:由于创建stu_view_4时没有使用检查选项,所以不需要检查5是否满足stu_view_4的查询条件,则5能够插入到student表中
    • 第二条插入数据:由于创建stu_view_4时没有使用检查选项,所以不需要检查16是否满足stu_view_4的查询条件,则16能够插入到student表中
    -- 创建stu_view_5视图
    create or replace view stu_view_5 as select id,name from stu_view_4 where id >= 10 with local check option;
    
    -- 向视图stu_view_5中插入数据
    insert into stu_view_5 values (13,'Tom'); -- 能够插入到student表中
    insert into stu_view_5 values (17,'Tom'); -- 能够插入到student表中
    

    解释:

    • 第一条插入数据:由于创建stu_view_5时使用检查选项,所以需要检查13是否满足stu_view_5的查询条件,即13>=10,则满足stu_view_5的检查条件;stu_view_5是基于stu_view_4创建的,则需要递归到stu_view_4,且由于stu_view_5使用的是local检查选项,且stu_view_4没有使用检查选项,则不需要检查13是否满足stu_view_4的查询条件,于是13能够插入到student表中
    • 第二条插入数据:由于创建stu_view_5时使用检查选项,所以需要检查17是否满足stu_view_5的查询条件,即17>=10,则满足stu_view_5的检查条件;stu_view_5是基于stu_view_4创建的,则需要递归到stu_view_4,且由于stu_view_5使用的是local检查选项,且stu_view_4没有使用检查选项,则不需要检查17是否满足stu_view_4的查询条件,于是17能够插入到student表中
    -- 创建stu_view_6视图
    create or replace view stu_view_6 as select id,name from stu_view_5 where id < 20;
    
    -- 向stu_view_6视图中插入数据
    insert into stu_view_6 values (14,'Tom');  -- 能够插入到student表中
    

    解释:

    • 由于创建stu_view_6时没有使用检查选项,所以不需要检查14是否满足stu_view_6的查询条件;由于stu_view_6是基于stu_view_5创建的,则需要递归到stu_view_5,由于stu_view_5使用检查选项,所以需要检查14是否满足stu_view_5的查询条件,即14>=10,则满足stu_view_5的检查条件;stu_view_5是基于stu_view_4创建的,则需要递归到stu_view_4,且由于stu_view_5使用的是local检查选项,且stu_view_4没有使用检查选项,则不需要检查14是否满足stu_view_4的查询条件,于是14能够插入到student表中
  • 案例2

    -- local 案例2
    -- 创建stu_view_4视图
    create or replace view stu_view_4 as select id,name from student where id <= 15 with local check option;
    
    -- 创建stu_view_5视图
    create or replace view stu_view_5 as select id,name from stu_view_4 where id >= 10 with local check option;
    
    -- 向视图stu_view_5中插入数据
    insert into stu_view_5 values (18,'Tom'); -- 不能插入到student表中
    

    解释:

    • 由于创建stu_view_5时使用检查选项,所以需要检查18是否满足stu_view_5的查询条件,即18>=10,则满足stu_view_5的检查条件;stu_view_5是基于stu_view_4创建的,则需要递归到stu_view_4,且由于stu_view_5使用的是local检查选项,同时stu_view_4也使用了检查选项,则需要检查18是否满足stu_view_4的查询条件,即18<=15,于是18不能够插入到student表中

总结:

cascaded:视图1使用cascaded检查选项,需要先检查插入数据是否满足视图1的查询条件;其次需要其次需要递归到视图1所依赖的视图2,检查插入数据是否满足视图1所依赖的视图2的查询条件(此时无论视图2是否使用了检查选项,都需要被检查),以此类推。

local:视图1使用了local检查选项,需要先检查插入数据是否满足视图1的查询条件;其次需要递归到视图1所依赖的视图2,若视图2使用了检查选项,则需要检查插入数据是否满足视图2的查询条件,以此类推。

4.1.3、更新及作用

1、视图的更新

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

  • 聚合函数或窗口函数(SUM()、MIN()、MAX()、COUNT()等)
  • DISTINCT
  • GROUP BY
  • HAVING
  • UNION或UNION ALL

在这里插入图片描述

2、作用

  • 简单

    视图不仅可以简化用户对数据的理解,也可以简化他们的操作。那些被经常使用的查询可以定义为视图,从而使得用户不必为以后的操作每次指定全部的操作。

  • 安全

    数据库可以授权,但不能授权到数据库特定行和特定列上。通过视图用户只能查询和修改他们所能见到的数据。

  • 数据独立

    视图可帮助用户屏蔽真实表结构变化带来的影响。

4.1.4、案例

根据如下要求,定义视图

1、为了保证数据库表的安全性,开发人员在操作tb_user表时,只能看到的用户的基本字段,屏蔽手机号和邮箱两个字段。

create view tb_user_view as select id,name,profession,age,gender,status,createtime from tb_user;

2、查询每个学生所选修的课程(三张表联查),这个功能在很多的业务中都有使用到,为了简化操作,定义一个视图。

create view student_view_course as select s.name student_name, s.no student_no, c.name course_name from student s, course c,student_course sc where s.id = sc.studentid and c.id = sc.courseid;

4.2、存储过程(procedure)

4.3、触发器(trigger)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/332968.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

源码级别的讲解JAVA 中的CAS

没有CAS之前实现线程安全 多线程环境不使用原子类保证线程安全&#xff08;基本数据类型&#xff09; public class T3 {volatile int number 0;//读取public int getNumber(){return number;}//写入加锁保证原子性public synchronized void setNumber(){number;} }多线程环…

代码随想录【Day09】|28. 找出字符串中第一个匹配项的下标、459. 重复的子字符串、《字符串总结》

28. 找出字符串中第一个匹配项的下标 题目链接 题目描述&#xff1a; 实现 strStr() 函数。 给定一个 haystack 字符串和一个 needle 字符串&#xff0c;在 haystack 字符串中找出 needle 字符串出现的第一个位置 (从0开始)。如果不存在&#xff0c;则返回 -1。 示例 1: 输…

计算机图形学:改进的中点BH算法

作者&#xff1a;非妃是公主 专栏&#xff1a;《计算机图形学》 博客地址&#xff1a;https://blog.csdn.net/myf_666 个性签&#xff1a;顺境不惰&#xff0c;逆境不馁&#xff0c;以心制境&#xff0c;万事可成。——曾国藩 文章目录专栏推荐专栏系列文章序一、改进缘由二、…

qt连接mysql,自编译生成驱动文件

CMakeninja编译qt所需的mysql驱动文件 想用qt连接mysql数据库&#xff0c;但是在qt6.0版本之后都不自带驱动需要自己编译&#xff0c;过程中由于不熟悉cmake以及ninja&#xff0c;踩了一百个坑&#xff0c;简单记录一下。 写在前面 csdn上也有很多大佬写得用cmake-gui来编译…

代码随想录算法训练营第43天DP动态规划62不同路径63 不同路径2

文章目录LeetCode 62不同路径题目讲解思路LeetCode 63 不同路径ii题目讲解思路小结LeetCode 62不同路径 题目讲解 思路 机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角&#xff08;在下图中标记为 “Finish” &#xff09;。 根据题意来看机器人只能进行向右…

单链表的基本操作

此代码不可运行&#xff0c;含伪代码。一、 定义数据域typedef struct{ char num[8];char name[8];int score;}ElemType;二、 定义一个链表typedef struct LNode{ElemType data; //链表中结点的数据域 struct Lnode *next; //为指向下一个结点的指针域&#xff0c;并且所指向的…

物理师知识大杂烩|CT模拟机质量控制指南

引言 放射治疗 CT 模拟机&#xff08;computed tomography simulators, CT-Sim&#xff09;由带有平板床面的 CT 扫描仪、用于患者定位与体表标记的外部激光系统、CT 模拟软件以及各种硬拷贝输出设备组成。CT 模拟机为放射治疗计划设计提供了患者肿瘤、正常组织与危及器官的影…

TMDSEVM6657LS评估板恢复出厂默认状态

TMDSEVM6657LS评估板恢复出厂默认状态 前言 TMDSEVM6657LS评估板特别适用于DSP开发的初学者&#xff0c;但有时候拿到手的开发板几经流转&#xff0c;被别人修改过&#xff0c;也可能自己烧录过程出错&#xff0c;导致开发板的状态未知等原因&#xff0c;需要恢复到出厂默认状…

Django的安装及创建项目

Django的安装及创建demo项目 打开PyCharm&#xff0c;选择创建Django项目勾选使用Virtualenv创建虚拟环境&#xff0c;并选择合适的Python编译器版本即可。 注&#xff1a;如果因为其他原因&#xff08;没有关闭vpn等&#xff09;也可以在PyCharm提供的terminal终端&#xf…

uni-app低成本封装一个取色器组件

在uni-ui中找不到对应的工具 后面想想也是 移动端取色干什么&#xff1f; 没办法 也挂不住特殊需求 因为去应用市场下载 这总东西 又不是很有必要 那么 下面这个组件或许能解决您的烦恼 <template><view class"content"><view class"dialog&…

侯捷C++系统工程师

前言我相信对于每一个学习C的同学和从业者来说&#xff0c;台湾著名学者侯捷老师的C系列都是不可错过的好视频。侯捷老师在网上已有五门课&#xff0c;分别是&#xff1a;C面向对象开发、STL标准库与泛型编程、C新标准C1&14、C内存管理机制以及C Startup揭秘讲师介绍侯捷老…

python基于django+vue的高铁地铁火车订票管理系统

目录 1 绪论 1 1.1课题背景 1 1.2课题研究现状 1 1.3初步设计方法与实施方案 2 1.4本文研究内容 2 2 系统开发环境 4 2.1 使用工具简介 4 2.2 环境配置 4 2.4 MySQL数据库 5 2.5 框架介绍 5 3 系统分析 6 3.1系统可行性分析 6 3.1.1经济可行性 6 3.1.2技术可行性 6 3.1.3运行可…

pandas——DataFrame基本操作(二)【建议收藏】

pandas——DataFrame基本操作&#xff08;二&#xff09; 文章目录pandas——DataFrame基本操作&#xff08;二&#xff09;一、实验目的二、实验原理三、实验环境四、实验内容五、实验步骤1.修改数据2.缺失值3.合并1.concat合并2.使用append方法合并3.使用merge进行合并4.使用…

为什么实时ERP系统是唯一的出路?

长期以来&#xff0c;企业主不得不等待数天&#xff0c;有时甚至数周&#xff0c;才能获得财务和运营结果。今天&#xff0c;尤其是在我们可以使用高速计算机和实时技术的情况下&#xff0c;这绝不应该成为可接受的标准。 然而&#xff0c;太多的大牌ERP系统仍然使用批量处理…

2023年网络安全比赛--Web综合渗透测试中职组(超详细)

一、竞赛时间 180分钟 共计3小时 二、竞赛阶段 1.通过URL访问http://靶机IP/1,对该页面进行渗透测试,将完成后返回的结果内容作为FLAG值提交; 2.通过URL访问http://靶机IP/2,对该页面进行渗透测试,将完成后返回的结果内容作为FLAG值提交; 3.通过URL访问http://靶机IP/3,对…

CDN绕过技术总汇

注 本文首发于合天网安实验室 首发链接&#xff1a;https://mp.weixin.qq.com/s/9oeUpFUZ_0FUu6YAhQGuAg 近日HVV培训以及面试&#xff0c;有人问了CDN该如何绕过找到目标真实IP&#xff0c;这向来是个老生常谈的问题&#xff0c;而且网上大多都有&#xff0c;但是有些不够全面…

中国网站安全形式风险报告

声明 本文是学习2017中国网站安全形势分析报告. 而整理的学习笔记,分享出来希望更多人受益,如果存在侵权请及时联系我们 网站漏洞检测分析 网站漏洞的整体形势可以从两个角度分析&#xff1a;一是网站安全检测的自动扫描结果统计&#xff0c;二是网站被报告漏洞情况的统计。…

FreeRTOS队列 | FreeRTOS九

目录 说明&#xff1a; 一、队列简介 1.1、什么是队列 1.2、队列的优势 1.3、队列实现功能 1.4、队列使用了解 1.5、队列特点 1.6、队列阻塞处理 1.7、队列出队入队过程 二、队列结构体 2.1、结构体了解 2.2、共同体了解 2.3、队列结构体存储区 三、队列API函数 …

nacos配置中心搭建

网站每次更新版本都有短暂暂停&#xff0c;影响用户使用&#xff0c;返回经常不可用&#xff0c;需要改进 需要实现高可用&#xff0c;搭建负载均衡&#xff0c;实现jenkinsnacos不停机部署 nacos搭建预备环境准备 64 bit OS&#xff0c;支持 Linux/Unix/Mac/Windows&#x…

vue2.0项目第一部分

论坛项目后端管理系统服务器地址&#xff1a;http://172.16.11.18:9090swagger地址&#xff1a;http://172.16.11.18:9090/doc.html前端h5地址&#xff1a;http://172.16.11.18:9099/h5/#/前端管理系统地址&#xff1a;http://172.16.11.18:9099/admin/#/搭建项目vue create . …