MySQL的逻辑分层

MySQL的逻辑分层,第1张

MySQL的逻辑分层只有四层

从客户端发起请求到服务端

client ==>连接层 ==>服务层==>引擎层==>存储层 server

连接层:连接与线程处理,这一层并不是MySQL独有,一般的基于C/S架构的都有类似组件,比如连接处理、授权认证、安全等。

服务层:包括缓存查询、解析器、优化器,这一部分是MySQL核心功能,包括解析、优化SQL语句,查询缓存目录,内置函数(日期、时间、加密等函数)的实现。

引擎层:负责数据存储,存储引擎的不同,存储方式、数据格式、提取方式等都不相同,这一部分也是很大影响数据存储与提取的性能的;对存储层的抽象。

存储层:存储数据,文件系统。

左连接:返回包括左表中的所有记录和右表中联结字段相等的记录

右连接:返回包括右表中的所有记录和左表中联结字段相等的记录

全连接:返回两个连接表的所有记录;mysql没有全连接

内连接:返回两个连接表连接字段相同的记录;

union:对两个结果集进行并集,并去重,当交换两个select语句顺序后,最终结果与不交换时无区别;

union all:对两个结果集进行并集,不去重,当交换两个select语句顺序后,最终结果与不交换时有区别;

举个例子 有一个学生表 班级 姓名 一个成绩表 姓名 成绩 我们需要返回X班的所有学生的成绩,但是班上有人缺考,也就是成绩表里没有姓名,我们先用on得到的就是有考试成绩的名字,通过外连接,我们就可以得到全班人的名字以及成绩。

SQL中的 join 可以根据相应条件把指定的表给结合起来并将数据返回。

内连接是基于连接谓词将俩张表(如A和B)的列组合到一起产生新的结果表,在表中存在至少一个匹配时,INNER JOIN 关键字返回行

左外连接Left join关键字会从左表那里返回所有的行,即使是在右表中没有匹配到的行 

右外连接关键字Right join会从右表那里返回所有的行,即使是在左表中没有匹配到的行 

全连接的关键字Full join,只要其中某个表中存在匹配,Full join 就会返回行

交叉连接一般使用的比较少,交叉连接又称笛卡尔连接或者叉乘连接,如果,A和B是俩个集合,他们的交叉连接就是A*B 


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/8594587.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-18
下一篇 2023-04-18

发表评论

登录后才能评论

评论列表(0条)

保存