MySQL篇(视图)(持续更新迭代)

devtools/2024/9/24 22:07:22/

目录

一、简介

二、语法

1. 创建

2. 查询

3. 修改

4. 删除

三、演示示例

1. 案例

2. 测试

3. 疑问

四、检查选项

1. 简介

2. 两种

2.1. CASCADED

2.2. LOCAL

五、视图的更新

1. 简介

2. 实例演示

六、视图的作用

1. 简单

2. 安全

3. 数据独立

七、演示案例


一、简介

视图(View)是一种虚拟存在的表。

视图中的数据并不在数据库中实际存在,行和列数据来自定义视图的查询中使用的表,并且是在使用视图时动

态生成的。

通俗的讲,视图只保存了查询的SQL逻辑,不保存查询结果。

所以我们在创建视图的时候,主要的工作就落在创建这条SQL查询语句上。

二、语法

1. 创建

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

2. 查询

查看创建视图语句:SHOW CREATE VIEW 视图名称;查看视图数据:SELECT * FROM 视图名称 ...... ;

3. 修改

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

4. 删除

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

三、演示示例

1. 案例

-- 创建视图
create or replace view stu_v_1 as select id,name from student where id <= 10;-- 查询视图
show create view stu_v_1;select * from stu_v_1;select * from stu_v_1 where id < 3;-- 修改视图
create or replace view stu_v_1 as select id,name,no from student where id <= 10;alter view stu_v_1 as select id,name from student where id <= 10;-- 删除视图
drop view if exists stu_v_1;

2. 测试

上述我们演示了,视图应该如何创建、查询、修改、删除,那么我们能不能通过视图来插入、更新数据呢?

接下来,做一个测试。

create or replace view stu_v_1 as select id,name from student where id <= 10 with cascaded check option;select * from stu_v_1;insert into stu_v_1 values(6,'Tom');insert into stu_v_1 values(17,'Tom22');

执行上述的SQL,我们会发现,id为6和17的数据都是可以成功插入的。

但是我们执行查询,查询出来的数据,却没有id为17的记录。

因为我们在创建视图的时候,指定的条件为 id<=10, id为17的数据,是不符合条件的,

所以没有查询出来,但是这条数据确实是已经成功的插入到了基表中

3. 疑问

问题:如果我们定义视图时,如果指定了条件,然后我们在插入、修改、删除数据时,是否可以做到必须满足

条件才能操作,否则不能够操作呢?

答案:是可以的,这就需要借助于视图的检查选项了

四、检查选项

1. 简介

当使用WITH CHECK OPTION子句创建视图时,MySQL会通过视图检查正在更改的每个行,

例如 插入,更新,删除,以使其符合视图的定义。

MySQL允许基于另一个视图创建视图,它还会检查依赖视图中的规则以保持一致性。

为了确定检查的范围,mysql提供了两个选项: CASCADED 和 LOCAL ,默认值为 CASCADED。

2. 两种

2.1. CASCADED

级联。

比如,v2视图是基于v1视图的,如果在v2视图创建的时候指定了检查选项为 cascaded,但是v1视图创建时未

指定检查选项。

则在执行检查时,不仅会检查v2,还会级联检查v2的关联视图v1。

2.2. LOCAL

本地。

比如,v2视图是基于v1视图的,如果在v2视图创建的时候指定了检查选项为 local ,但是v1视图创建时未指定检查选项。

则在执行检查时,只会检查v2,不会检查v2的关联视图v1。

五、视图的更新

1. 简介

要使视图可更新,视图中的行与基础表中的行之间必须存在一对一的关系。

如果视图包含以下任何一项,则该视图不可更新:

聚合函数或窗口函数(SUM()、MIN()、 MAX()、 CO2UNT()等)

  • DISTINCT
  • GROUP BY
  • HAVING
  • UNION 或者 UNION ALL

2. 实例演示

create view stu_v_count as select count(*) from student;

上述的视图中,就只有一个单行单列的数据,如果我们对这个视图进行更新或插入的,将会报错。

insert into stu_v_count values(10);

错误信息如下:

六、视图的作用

1. 简单

视图不仅可以简化用户对数据的理解,也可以简化他们的操作。

那些被经常使用的查询可以被定义为视图,从而使得用户不必为以后的操作每次指定全部的条件。

2. 安全

数据库可以授权,但不能授权到数据库特定行和特定的列上。

通过视图用户只能查询和修改他们所能见到的数据

3. 数据独立

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

七、演示案例

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

个字段。

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

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

视图。

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


http://www.ppmy.cn/devtools/116688.html

相关文章

基于php的小说阅读系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、SSM项目源码 系统展示 【2025最新】基于phpvueMySQL的小说阅读系…

java高手集锦

在入职在行业后&#xff0c;特别是这四五年内&#xff0c;本菜鸟遇到了很多行业中的大师&#xff0c;在此我想展示一下大师的代码片断&#xff0c;以及与大师的对话录。以便让有幸能读到此系列文章的人能领略大师的风范。 大师的代码&#xff1a; public void doSomeThing(){A…

【Proteus单片机仿真】基于51单片机的循迹小车避障+气体传感器和温度传感器系统

目录 一、主要功能 二、硬件资源 三、程序编程 四、实现现象 一、主要功能 开机即两个直流电机运转&#xff0c;然后三个气体传感器&#xff0c;如果超过阈值&#xff0c;即蜂鸣器报警&#xff1b; 超声波传感器&#xff0c;如果检测到障碍&#xff0c;电机停止&#xff1…

HarmonyOS开发者基础认证考试试题

文章目录 一、判断题二、单选题三、多选题 因考试只有91分&#xff0c;所以下方答案有部分错误&#xff0c;如果有发现错误&#xff0c;欢迎提出 一、判断题 1. HarmonyOS提供了基础的应用加固安全能力&#xff0c;包括混淆、加密和代码签名能力 正确 2. 用户首选项是关系型数…

Spring全家桶

Spring全家桶是一套广泛使用的Java企业级开发框架&#xff0c;它集成了多个子项目和组件&#xff0c;旨在简化企业级应用的开发、部署和管理。以下是一个详细的Spring全家桶使用教程&#xff0c;涵盖了Spring框架的基本概念、核心组件、常用模块以及如何使用这些组件构建企业级…

【运维】自定义exporter

文章目录 环境准备代码编写搭建开发环境和包依赖创建main文件并进行初始化添加prometheus metrics endpoint并监听服务端口通过模拟url获取监控项的值通过编写函数获取监控项的值声明prometheus指标信息声明prometheus接口框架在main函数中声明exporter并注册 完整代码如下 环境…

一.python入门

gyp的读研日记&#xff0c;哈哈哈哈&#xff0c;&#x1f642;&#xff0c;从复习python开始&#xff0c; 目录 1.python入门 1.1 Python说明书 1.2 Python具备的功能 1.3 学习前提 1.4 何为Python 1.5 编程语言 2.Python环境搭建 2.1 开发环境概述 2.2 Python的安装与…

初始爬虫6

数据提取 数据提取总结 响应分类 结构化 json数据&#xff08;高频出现&#xff09; json模块 jsonpath模块 xml数据&#xff08;低频出现&#xff09; re模块 …