【MYSQL】MYSQL逻辑架构

mysql逻辑架构分为3层

mysql逻辑架构分为3层

1). 连接层:主要完成一些类似连接处理,授权认证及相关的安全方案。

2). 服务层:在 MySQL据库系统处理底层数据之前的所有工作都是在这一层完成的,包括权限判断,SQL接口,SQL解析,SQL分析优化, 缓存查询的处理以及部分内置函数执行(如日期,时间,数学运算,加密)等等。各个存储引擎提供的功能都集中在这一层,如存储过程,触发器,视图等。

3). 引擎层:是底层数据存取操作实现部分,由多种存储引擎共同组成。真正负责MySQL中数据的存储和提取。针对特殊数据引擎还要做事务处理。

回表发生在哪一层

MySQL的回表操作发生在存储引擎层。‌

回表操作是基于物理地址来获取数据的过程,‌这一过程主要在MySQL的存储引擎层进行。‌当执行一条SQL语句时,‌如果需要从两个B+索引中去取数据,‌就会发生回表操作。‌具体来说,‌回表操作通常涉及到以下情况:‌

使用非聚簇索引:‌当表中没有定义主键或者查询条件没有使用主键时,‌非聚簇索引成为主要的索引选择,‌此时回表操作难以避免。‌

数据修改:‌如果在回表过程中发生了数据修改(‌如DELETE、‌UPDATE)‌,‌则可能会读取到不一致或错误的数据。‌

覆盖索引的判断:‌在选择是否使用覆盖索引时,‌需要综合考虑查询的字段以及字段长度,‌以及查询操作的频率和数据量。‌如果查询需要返回的字段较多或字段长度较长,‌可能需要权衡回表带来的性能损耗和数据完整性的需求。‌

在实际应用中,‌回表操作可能因为上述原因而发生,‌但这一过程主要在MySQL的存储引擎层进行处理,‌特别是对于InnoDB存储引擎而言,‌其内部机制负责处理这些索引和数据的交互操作

相关推荐
步步为营DotNet几秒前
5-2EFCore性能优化
数据库·性能优化·.net
2501_920047031 小时前
Redis-集群
数据库·redis·bootstrap
半夏陌离1 小时前
SQL 拓展指南:不同数据库差异对比(MySQL/Oracle/SQL Server 基础区别)
大数据·数据库·sql·mysql·oracle·数据库架构
旋转的油纸伞2 小时前
SQL表一共有几种写入方式
数据库·sql
半夏陌离2 小时前
SQL 入门指南:排序与分页查询(ORDER BY 多字段排序、LIMIT 分页实战)
java·前端·数据库
isyoungboy2 小时前
SQL高效处理海量GPS轨迹数据:人员gps轨迹数据抽稀实战指南
数据库·sql
敬业小码哥2 小时前
记一次:mysql的json及json数组使用组合使用
数据库·mysql·json
练小杰3 小时前
【Mysql-installer-community-8.0.26.0】Mysql 社区版(8.0.26.0) 在Window 系统的默认安装配置
数据库·sql·mysql·adb·配置文件·mysql安装·关系型数据库
LQ深蹲不写BUG3 小时前
微服务的保护方式以及Sentinel详解
微服务·云原生·架构
失散133 小时前
分布式专题——1.2 Redis7核心数据结构
java·数据结构·redis·分布式·架构