【MySQL进阶】MySQL视图详解

news2025/1/12 1:34:10
序号系列文章
6【MySQL基础】MySQL单表操作详解
7【MySQL基础】运算符及相关函数详解
8【MySQL基础】MySQL多表操作详解
9【MySQL进阶】MySQL事务详解

文章目录

  • 前言
    • 1,视图
      • 1.1,视图概述
      • 1.2,视图使用环境
      • 1.3,视图创建格式
      • 1.4,视图创建注意
    • 2,视图操作
      • 2.1,创建视图
      • 2.2,查看视图
      • 2.3,修改视图
      • 2.4,删除视图
    • 3,视图数据操作
      • 3.1,添加数据
      • 3.2,修改数据
      • 3.3,删除数据
      • 3.4,扩展知识
    • 4,视图检查条件
      • 4.1,级联检查
      • 4.2,非级联检查
    • 5,视图的优缺点
      • 5.1,视图的优点
      • 5.2,视图的缺点
  • 结语


前言

大家好,我是小杨!前面我已经为大家介绍了MySQL中的进阶知识->事务,那么今天我们就给大家讲解MySQL中的视图这部分的相关内容,希望大家能够收获多多!


1,视图

1.1,视图概述

视图的定义:一种从一个或多个数据表中导出来的虚拟存在的表,本身是不具有数据记录的。

视图的创建是建立已有表的基础之上,而这些视图赖以建立的表称为基表。也就是,创建的表结构和表数据记录都是依赖于基表。

视图的功能:不仅可以查看到存放在基表中的数据,还可以像操作基本表一样,对数据进行查询,添加,更新,修改和删除的操作。

视图的总结:在数据库中,视图不会保存数据,是虚拟存在的表,数据真正保存在数据表中。视图的创建和删除只会影响视图本身,不会影响对应的基表。当对视图中的数据进行增加、删除和修改操作时,与之对应的基表中的数据记录会相应地发生变化;当对基表中的数据进行增加,删除和操作时,与之对应的视图中的数据记录也会发生相对应的变化。


1.2,视图使用环境

在公司中,每个部门之间相互配合,完成自己对应的任务。而公司的信息数据(人员信息,财务信息,… )都被保存到公司的数据库中,如果不同部门的员工想对公司的信息数据进行操作时,直接将公司数据都打印出来,这就会导致一系列的问题。

而我们希望的是不同部门,不同级别的员工所拥有的权限是不同的,进而操作所得到的结果也是不一样的。那如何才能实现呢?

视图的存在就可以实现上述希望,视图一方面可以让我们只使用表中的一部分数据,而不是使用表中的所有数据;另一方面也可以针对不同的用户制定不同的查询视图。比如,针对一个公司的销售人员,我们只希望给他看部分数据,而某些特殊的数据,比如采购的价格,则不会提供给他。再比如,人员薪酬是个敏感的字段,那么这个字段的数据的操作权限只能给特定级别以上的人员开放,而其他人在查询视图时,则不会查询到这个字段的信息。

总的来说,视图其实就是向用户提供基表数据的另一种表现形式。通常情况下,小型项目的数据库可以不使用视图,但是在大型项目中,以及数据表比较复杂的情况下,视图的价值就凸显出来了,它可以帮助我们把经常查询的结果集放到虚拟表中,提升使用效率,理解和使用起来都非常方便。


1.3,视图创建格式

创建视图通过使用CREATE VIEW 语句来进行创建,其基本语法为:

CREATE [OR REPLACE] [ALGORITHM][DEFINER][SQL SECURITY] 
VIEW view_name [column_list] AS select_statement [WITH [CASCADED | LOCAL]] CHECK OPTION;

上述语法中各个参数代表的含义为:

1,OR REPLACE,可选参数,表示替换已有视图

2,ALGORITHM,可选,表示视图算法,会影响查询语句的解析方法,它的取值有以下3种:

  • UNDEFINED(默认),由MySQL自动选择算法。
  • MERGR,将select_statement和查询视图时的SELECT语句合并起来进行查询。
  • TEMPTABLE,先将select_statement的查询结果存入临时表,然后用临时表进行查询

3,DEFINER,可选,表示定义视图的用户,与安全控制有关,默认为当前用户。

4,SQL SECURITY,可选,用于视图的安全控制,它的取值有以下2种:

  • DEFINER(默认),由定义者指定的用户的权限来执行。
  • INVOKER,由调用视图的用户的权限来进行。

5,view_name,表示要创建的视图名称

6,column_list,可选,用于指定视图中的各个字段名。默认情况下,与SELECT语句查询的字段相同。

7,AS,表示视图要执行的操作

8,select_statement,查询语句,表示从基表或视图中查询出满足条件的记录,然后将这些数据记录导入视图中。

9,WITH CHECK OPTION,可选,用于视图数据操作时的检查条件,若省略,则不进行检查,它的取值有以下2种:

  • CASCADED(默认),操作数据时满足所有有关视图和表定义的条件。
  • LOCAL,操作数据时只需要满足该视图本身定义的条件。

看到上面的这些参数,可能会对视图产生一种畏惧心理了,尽管视图的创建语法参数这么多,但我们在实际创建时,因只是简单操作,不注重什么用户,权限问题,因此就只需要使用以下缩减版语法来进行视图的创建。语法缩减为:

CREATE [OR REPLACE] VIEW view_name [column_list] 
AS select_statement [WITH [CASCADED | LOCAL] CHECK OPTION];

1.4,视图创建注意

1,在默认情况下,新创建的视图保存在当前选择的数据库中。若想要明确地指定在某个数据库中创建视图,在创建时应将名称指定数据库名.视图名

2,在进行SHOW TABLES操作时,查询到的结果中不仅包含了该数据库中的数据表,还包含了已经创建好的视图。

3,创建视图要求用户具有CREATE VIEW权限,以及查询涉及到的SELECT权限。若有OR REPLACE子句,还必须具有视图的DROP权限。

4,在同一个数据库中,新创建视图的视图名称不能与已经存在的表名称相同,如果相同,会创建失败。

5,当一个视图创建完成后,MySQL就会在数据库目录上创建一个名为视图名.frm的文件。


2,视图操作

视图是虚拟存在的表,本身是不具有数据记录的。视图的创建和删除只会影响视图本身,不会影响对应的基表。

2.1,创建视图

1,单表视图创建

CREATE VIEW view_name [column_list] AS select_statement [WITH [CASCADED | LOCAL] CHECK OPTION];

为了更好的理解单表视图的创建,示例如下:

image-20230123181351677

在上述单表视图的创建后,从视图中查询到的数据记录与直接在基表查询的数据相同。视图也能像基表一样对查询到的数据记录进行排序,限量,排序等一系列操作。

在进行SHOW TABLES操作时,查询到的结果中不仅包含了该数据库中的数据表,还包含了已经创建好的视图。

在查询视图时,SELECT字段列表和WHERE等子句中的字段,只能使用创建视图时指定的SELECT语句中的字段,就如上述操作中的id,name,score,group_id 这些字段,而其它的字段无法通过view_group_1视图进行查询,若使用,则会报错。

在创建视图时,没有在视图名后面指定字段列表,则视图中字段列表默认和SELECT语句中的字段列表一致。如果SELECT语句中给字段取了别名,那么视图中的字段名和别名相同。

在创建视图时,可以对视图的字段名称进行自定义,而自定义列名称的顺序与AS后的SELECT字段列表顺序一致,且自定义列名称的数量必须与SELECT字段列表的数量一致,若数量不一致,MySQL会报错,无法成功创建视图。


2,多表视图创建

CREATE VIEW view_name [column_list] AS select_statement [WITH [CASCADED | LOCAL] CHECK OPTION];

为了更好的理解多表视图的创建,示例如下:

image-20230123225717241

在上述视图创建时,AS后的select_statement涉及到多张数据表的查询时,则创建出来的视图就被称为多表视图。

在进行SHOW TABLES操作时,查询到的结果中不仅包含了该数据库中的数据表,还包含了已经创建好的视图。


2.2,查看视图

1,查看视图的字段信息

DESC view_name;

为了更好的理解视图的查看操作,示例如下:

image-20230123232205022

在上述的操作中,我们看到可以通过DESC view_name查询到视图的字段信息。

因此,我们可以得出:DESC在MySQL中不仅可用来查询数据表的字段信息,也可以用来查询视图的字段信息。


2,查看视图状态信息

SHOW TABLE STATUS LIKE 'view_name'\G;

为了更好的理解视图状态信息的查看,示例如下:

image-20230123232536437

在上述操作结果中,我们可以发现除了NameComment之外,其余的信息均为NULL。Name表示名称,而Comment的值为VIEW,表示所查的view_emp是一个视图。

因此,我们可以得出:SHOW TABLE STATUS在MySQL中不仅可用来查询数据表的状态信息,也可以用来查询视图的状态信息。


3,查看视图的创建语句

#方式1:
SHOW CREATE VIEW view_name \G;

#方式2:
SHOW CREATE TABLE view_name \G;

为了更好的理解视图创建信息的查看,示例如下:

image-20230123232920359

在上述操作结果中,我们可以发现使用SHOW CREATE VIEW view_emp或使用SHOW CREATE TABLE view_emp可以查看到view_emp视图的名称,创建语句以及其的字符编码等信息。

因此,我们可以得出:SHOW CREATE VIEW view_nameSHOW CREATE TABLE view_name在MySQL中可用来查询创建视图时的定义语句以及视图的字符编码等信息。


2.3,修改视图

修改视图是指修改数据库中存在的视图的定义。例如当基本表的某些字段发生变化时,视图必须修改后才能正常使用。

在MySQL中,修改视图的方式有2种,分别为替换已有的视图和使用ALTER VIEW语句修改视图这两种方式。

1,替换已有的视图

CREATE OR REPLACE VIEW view_name [column_list] AS select_statement [WITH [CASCADED | LOCAL]] CHECK OPTION;

语法:通过CREATE OR REPLACE VIEW语句可以在创建视图时替换已有的同名视图,如果视图不存在,则进行创建一个视图操作。

为了更好的理解通过替换已有的视图来修改视图,示例如下:

image-20230124093806880

从上述操作中,通过CREATE OR REPLACE VIEW语句可以在创建视图时替换已有的同名视图,如果视图不存在,则进行创建一个视图操作。


2,使用ALTER VIEW语句修改

ALTER [ALGORITHM][DEFINER][SQL SECURITY] VIEW view_name [column_list] 
AS select_statement [WITH [CASCADED | LOCAL]] CHECK OPTION;

语法:ALTER后面的各部分子句与CREATE VIEW语句中的含义相同。

为了更好的理解通过使用ALTER VIEW语句修改视图,示例如下:

image-20230125153911337


2.4,删除视图

当视图不再需要时,可以将其删除,在删除视图时不会删除基本表中的数据。

删除单个视图或多个视图都是通过使用DROP VIEW语句,基本语法如下:

#删除单个视图
DROP VIEW [IF EXISTS] view_name;

#删除多个视图
DROP VIEW [IF EXISTS] view_name,view_name...;

为了更好的理解视图的删除操作,示例如下:

image-20230125154937234

在上述操作中,删除单个或者多个视图操作中加上IF EXISTS避免了视图不存在而发生报错的情况,而视图名之间用逗号隔开。而这个视图的删除操作只会影响视图本身,不会影响对应的基表。


3,视图数据操作

视图数据操作就是通过视图来进行查询,添加,修改或删除基本表的数据。因为视图是一个虚拟存在的表,不保存数据,当对视图数据进行操作时,就相当于对基本表数据进行操作。

3.1,添加数据

通过视图向基本表添加数据时,可以使用INSERT INTO语句完成数据的添加操作。

INSERT INTO view_name VALUES(column_value,...);

为了更好的理解视图数据的添加操作,示例如下:

image-20230125161034324

在上述视图进行添加数据时,与之对应的基表的数据会发生变化,数据数添加。如果添加的数据与视图的创建条件相符合,则添加的数据就可以在视图中显示出来,如果不符合,就不可以在视图中显示,但要记住一点,不管添加的数据是否符合视图的创建条件,只要在创建视图时没有加上WITH CASCADED CHECK OPTION 或者WITH LOCAL CHECK OPTION检查条件,这个数据都会在对应的基表中添加并显示。

还有就是,直接对数据表进行数据添加操作,如果添加的数据符合视图的创建条件,则添加的数据也能够在视图中显示,如果不符合,就不显示出来。

添加数据的操作本质为:当对视图数据进行添加操作时,就相当于对基本表数据进行添加操作。


3.2,修改数据

通过视图修改基本表数据时,可以使用UPDATE语句完成数据的修改操作。

#修改单个字段数据:
UPDATE view_name SET column_name = column_value [WHERE 条件表达式];

#修改多个字段数据:
UPDATE view_name SET column_name = column_value,column_name = column_value,... [WHERE 条件表达式];

为了更好的理解视图数据的修改操作,示例如下:

image-20230125160821035

在对上述视图进行修改数据操作时,如果修改后的数据不符合视图的创建条件,就不会在视图中显示,不要因此就认为该数据记录消失了,其实该数据还是存在于基表中,并完成了对应的修改操作,只是不在视图中显示罢了。

修改数据的操作本质为:当对视图数据进行修改数据操作时,就相当于对基本表数据进行修改数据操作。


3.3,删除数据

通过视图删除基本表数据时,可以使用DELETE语句完成数据的删除操作。

DELETE FROM view_name [WHERE 条件表达式]; 

为了更好的理解视图数据的删除操作,示例如下:

image-20230125161342195

在上述视图中进行删除数据操作,视图中符合条件的数据记录和其与之对应的基表的数据记录都会删除。

删除数据的操作本质为:当对视图数据进行删除操作时,就相当于对基本表数据进行删除操作。


3.4,扩展知识

在进行视图数据操作时,如果遇到如下几种情况,操作可能会失败。

1,所操作的视图定义在多个数据表上

2,未满足视图基本表对字段的约束条件

3,在定义的SELECT语句后的字段列表中使用了数学表达式或者聚合函数。

4,在定义的SELECT语句中使用了DISTINCT,UNION,TOP,GROUP BY或HAVING子句


4,视图检查条件

在创建视图的语法格式中,WITH CHECK OPTION子句用于视图数据操作时进行条件检查,分为级联检查和非级联检查。

4.1,级联检查

在创建视图时,使用CASCADED进行级联检查,系统默认,操作数据时满足所有有关视图和表定义的条件,如不满足,则操作数据失败。

为了更好的理解视图的级联检查操作,示例如下:

image-20230125213243092

操作说明:首先依赖student数据表创建满足成绩大于92的学生信息的视图view_1,无检查条件;再依赖于view_1视图创建满足成绩低于96的学生信息的视图view_2,存在检查条件CASCADED;然后在对视图view_2添加符合成绩在92到96之间的数据记录,数据记录添加成功;最后在往视图view_2添加不符合成绩在92到96之间的数据记录,数据记录添加失败,系统报错。

因此,在创建视图时,若使用CASCADED进行级联检查,操作数据要满足所有有关视图和表定义的条件,如不满足,则操作数据失败。


4.2,非级联检查

在创建视图时,使用LOCAL进行非级联检查,操作数据时只需要满足该视图本身定义的条件,如不满足,则操作数据失败。

为了更好的理解视图的非级联检查操作,示例如下:

image-20230125213727879

操作说明:首先依赖student数据表创建满足成绩大于92的学生信息的视图view_1,无检查条件;再依赖于view_1视图创建满足成绩低于96的学生信息的视图view_3,存在检查条件LOCAL;然后在对视图view_3添加满足成绩小于96,但不大于92的数据记录,数据记录添加成功;最后在往视图view_2添加不满足成绩小于96的数据记录,数据记录添加失败,系统报错。

因此,在创建视图时,若使用LOCAL进行非级联检查,操作数据时只需要满足该视图本身定义的条件,如不满足,则操作数据失败。


5,视图的优缺点

5.1,视图的优点

1,简化查询语句

通过视图可以简化查询语句,简化用户的查询操作,使查询更加快捷。在日常开发中,将经常使用的查询定义为视图,从而避免了大量的重复操作,同时也极大简化了开发人员对数据库的操作。

2, 减少数据冗余

视图跟实际数据表不一样,视图存储的是查询语句。所以在使用的时候,我们要通过定义视图的查询语句来获取结果集,而视图本身是不存储数据的,因此不占用数据存储的资源,进而减少了数据冗余。

3, 数据安全

MySQL将用户对数据的访问限制在某些数据的结果集上,而这些数据的结果集可以使用视图来实现,用户不必直接查询或操作数据表。

MySQL可根据权限将用户对数据的访问限制在某些视图上,用户不再需要查询数据表,可以直接通过视图获取数据表中的信息,这在一定程度上保障了数据表中数据的安全性。

可简单理解为:通过视图可以更方便地进行权限控制,能使特定的用户只能查询和修改他们所看到的数据记录,数据库中的其它数据是无法进行查看修改的,提高了数据的安全性。

4, 逻辑数据独立性

视图可以屏蔽真实表结构变化带来的影响。

例如,当其它应用程序进行查询数据时,若直接进行查询数据表,一旦数据表的表结构发生变化,查询的SQL语句就会发生改变,应用程序也会发生改变;但若是为程序提供视图,修改表结构后,只需要修改视图对应的SELECT语句,无需修改应用程序。

总结:当系统的业务需求发生变化后,也就是指数据表的表结构发生变化时,如果未使用视图,则工作量相对较大,视图的使用可以减少改动的工作量,提高效率。

5,能够分解复杂的查询逻辑

如果数据库中存在复杂的查询逻辑,则可以将此复杂的查询逻辑进行分解成多个简单的查询逻辑,进而通过创建多个视图来获取简单的查询逻辑数据,然后再将创建出来的多个视图进行结合,进而完成复杂的查询逻辑操作,可将此归纳为4个字:化繁为简。


5.2,视图的缺点

1,性能较低:通过视图进行数据查询操作,数据查询操作速度可能会很慢,特别是视图是基于其他视图创建的。

2,维护复杂:视图是依赖于基表的,每当更改与视图相关联的数据表的表结构时,都必须进行视图更改操作,尤其是嵌套视图。

3,修改限制:当用户试图修改视图的某些信息时,数据库必须把它转化为对基本表的某些信息的修改,对于简单的视图来说,还挺方便的,但对于比较复杂的视图,可能就不能进行修改了。


结语

这就是本期博客的全部内容啦,想必大家已经对MySQL中的视图的相关知识有了全新地认识和理解吧,如果有什么其他的问题无法自己解决,可以在评论区留言哦!

最后,如果你觉得这篇文章写的还不错的话或者有所收获的话,麻烦小伙伴们动动你们的小手,给个三连呗(点赞👍,评论✍,收藏📖),多多支持一下!各位的支持是我最大的动力,后期不断更新优质的内容来帮助大家,一起进步。那我们下期见!

在这里插入图片描述


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

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

相关文章

【C语言课堂】 函数递归

欢迎来到 Claffic 的博客 💞💞💞 前言: 时隔多日,来还欠大家的 C 语言学习啦,上期讲了函数,其实函数中应该包括函数递归的,这里单独拿出来讲解的原因是函数递归属于重难知识&#xf…

【编程入门】开源记事本(Flutter版)

背景 前面已输出多个系列: 《十余种编程语言做个计算器》 《十余种编程语言写2048小游戏》 《17种编程语言10种排序算法》 《十余种编程语言写博客系统》 《十余种编程语言写云笔记》 本系列对比云笔记,将更为简化,去掉了网络调用&#xff0…

数据结构入门(力扣算法)

数据结构入门前面的题号为力扣的题号数组的217. 存在重复元素53. 最大子数组和1. 两数之和88. 合并两个有序数组350. 两个数组的交集 II121. 买卖股票的最佳时机566. 重塑矩阵118. 杨辉三角36. 有效的数独73. 矩阵置零字符串的387. 字符串中的第一个唯一字符383. 赎金信242. 有…

LeetCode 437. 路径总和 III

LeetCode 437. 路径总和 III 给定一个二叉树的根节点 root ,和一个整数 targetSum ,求该二叉树里节点值之和等于 targetSum 的 路径 的数目。 路径 不需要从根节点开始,也不需要在叶子节点结束,但是路径方向必须是向下的&#xff…

JUC面试(十一)——LockSupport

可重入锁 可重入锁又名递归锁 是指在同一个线程在外层方法获取锁的时候,再进入该线程的内层方法会自动获取锁(前提,锁对象得是同一个对象),不会因为之前已经获取过的锁还没释放而阻塞。 Java中ReentrantLock和synchronized都是可重入锁&am…

第一章 概述

第一章 概述 1.1 计算机网络在信息时代中的作用 21世纪的一些重要特征 数字化,网络化和信息化 以网络为核心的信息时代 互联网的两个重要基本特点 连通性共享(资源共享) 1.2 互联网概述 计算机网络由若干个结点货连接这些结点的链路组成…

【唐诗学习】四、边塞诗派代表

四、边塞诗派代表 边塞诗派起源 盛唐是中国历史上一个空前的盛世,国库丰盈,社会十分安定,百姓的幸福指数高。 盛唐是中国历史上一个空前的盛世,国库丰盈,社会十分安定,百姓的幸福指数高。唐太宗以后的几个…

Citadel——Dusk网络的Zero-Knowledge KYC解决方案

1. 引言 近期,Dusk网络宣布其已支持名为Citadel的Zero-Knowledge KYC解决方案,使得用户和机构可控制其权限以及个人信息分享。该架构可用于all claim-based KYC requests,并让用户完全控制他们共享的信息以及与谁共享信息,同时完…

详解Java中的BIO、NIO、AIO

1、 详解Java中的BIO、NIO、AIO 1.1、引言 IO流是Java中比较难理解的一个知识点,但是IO流在实际的开发场景中经常会使用到,比如Dubbo底层就是NIO进行通讯。本文将介绍Java发展过程中出现的三种IO:BIO、NIO以及AIO,重点介绍NIO。…

【c语言进阶】常见的静态通讯录

🚀write in front🚀 📜所属专栏:c语言学习 🛰️博客主页:睿睿的博客主页 🛰️代码仓库:🎉VS2022_C语言仓库 🎡您的点赞、关注、收藏、评论,是对我…

2.H3CNE-网络参考模型

OSI参考模型产生背景各大IT设备厂商只支持自己的私有协议,跨厂商设备兼容性差用户购买和维护成本高不利于网络技术发展概念定义了网络中设备所遵守的层次结构优点开放的标准化接口,协议不再封闭多厂商设备兼容易于理解、学习和更新协议标准实现模块化工程…

【Leetcode刷题】141、环形链表

原题链接:https://leetcode.cn/problems/linked-list-cycle/?favorite2cktkvj给你一个链表的头节点 head ,判断链表中是否有环。如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的…

Python数据可视化(二)使用统计函数绘制简单图形

该文会讲解一些大家比较熟悉却又经常混淆的统计图形,掌握这些统计图形可以对数据可视化有一个深入理解,并正确使用。2.1 函数 bar()——用于绘制柱状图函数功能:在 x 轴上绘制定性数据的分布特征。调用签名:plt.bar(x,y)。参数说明…

day21|216.组合总和III、17.电话号码的字母组合

216.组合总和III 找出所有相加之和为 n 的 k 个数的组合,且满足下列条件: 只使用数字1到9每个数字 最多使用一次 返回所有可能的有效组合的列表 。该列表不能包含相同的组合两次,组合可以以任何顺序返回。 示例 1: 输入: k 3, n 7 输出: …

说说配置中心

什么是配置中心在微服务的环境下,将项目需要的配置信息保存在配置中心,需要读取时直接从配置中心读取,方便配置管理的微服务工具可以将部分yml文件的内容保存在配置中心一个微服务项目有很多子模块,这些子模块可能在不同的服务器上,如果有一些统一的修改,需要逐一修改这些子模块…

python数据可视化开发:Matplotlib库基础知识

文章目录前言01.工具栏组件02.图表数据03.设置字体字典(1)全局字体样式(2)常用中文字体对应名称(3)查询当前系统所有字体04.图像配置实例05.图表标题06.文本组件07.坐标轴标签组件08.网格组件09.绘制折线10…

【头歌】双向链表的基本操作

双向链表的基本操作第1关:双向链表的插入操作任务描述本关任务:编写双向链表的插入操作函数。相关知识双链表中用两个指针表示结点间的逻辑关系:指向其前驱结点的指针域prior,指向其后继结点的指针域next。双向链表的结点结构如图…

MySQL数据库面试题[万字汇总]

1) MySQL数据库相关错题本1、存储引擎相关1、MySql的存储引擎的不同MySQL存储引擎主要有InnoDB, MyISAM, Memory, 这三个区别在于:Memory是内存数据引擎, 会断电重启(在双M或者主从架构下会产生较多异常), 且不支持行级锁. 默认索引是数组索引, 支持B索引InnoDB和MyISAM的区别:…

流批一体计算引擎-5-[Flink]的Python Table API和SQL程序

参考Flink从入门到入土(详细教程) 参考flink的默认窗口触发机制 参考彻底搞清Flink中的Window 参考官方Python API文档 1 IDEA中运行Flink 从Flink 1.11版本开始, PyFlink 作业支持在 Windows 系统上运行,因此您也可以在 Windows 上开发和…

【数据结构】极致详解:树与二叉树(上)——结构与概念

目录 🛫前言🛫: 🚀一、树🚀: 1.树的概念: 2.树的相关概念: 3.树的表示: 4.树的实际使用场景: 🛰️二、二叉树🛰️:…