首页 > 数据库 >mysql系列之一条sql的旅程(二)

mysql系列之一条sql的旅程(二)

时间:2024-04-07 23:13:25浏览次数:28  
标签:存储 缓存 log 旅程 sql server mysql

  在介绍一条sql是怎么执行的之前,我们先来了解一下mysql的架构:

  

 

如上图mysql主要分为server层和存储引擎层:

  server层算是mysql的核心能力层,如sql语句的解析优化,权限管控,各类的sql函数、存储过程,以及自身数据备份,恢复等高级功能(binlog实现),我们用到的一些基础的增删改查,这里都实现了。

  存储引擎我们比较最熟悉的便是innodb,其他的比如mylsam,memory等等,每种存储引擎都有自己的特点,适用于不同的业务场景,而innodb由于其支持事务,行级锁和外键约束等特点,受到广泛欢迎。除此之外innodb还有着自己的日志系统redo log(重做日志)和undo log(撤销日志),redo log用于保证事务的持久性,本节后面我们也会聊到这一点,undo log主要用于事务回滚和多版本并发控制(mvcc) ,这块后续会详细介绍。存储引擎层在我看来相当于server层的插件,增强了mysql的能力。

  那么一条sql又是如何在mysql的架构上流转的呢:

  客户端访问mysql最先访问的便是server层的连接器,玩过的应该都知道,首先需要输入用户名和密码,连接器主要做的便是身份认证和权限校验。

  接下来一般会来查询缓存(8.0以后去除了查询缓存),mysql会以key-value的形式,key是sql语句,所以知道为啥8.0以后去掉了吧,因为我们绝大多数业务是疯狂变化的,基本上大部分场景查询语句都不一样,而那些基本不变动的反而可以通过离用户更近的本地缓存或者第三方缓存如redis来处理,完全没必要再走mysql的查询缓存。

  再往后便是分析器,它会分析你的语法是否合法,会从information_schema中获取到对应的表结构,和sql作对比。

  之后便是优化器,会计算你使用什么索引更合适,会优化你的join查询(一般会优化成小表驱动大表)

  确定好要做什么后,便会来到执行器,执行器会调用存储引擎提供的接口,最终将整合的数据结果返回给客户端。

至此一条sql也执行完毕了,看着是比较简单的,但其实每个里面的功能都特别复杂,想想优化器是怎么优化的,怎么就知道我该用哪个怎么用呢,这个后面有机会再聊。

 

   

  

 

标签:存储,缓存,log,旅程,sql,server,mysql
From: https://www.cnblogs.com/gmt-hao/p/18120133

相关文章

  • SQL窗口函数的移动求和/平均,及相应的Leecode题目
    原文链接:https://blog.csdn.net/weixin_45638528/article/details/130229603移动求和的窗口函数——连续n个数据求和sum(字段1)over(partitionby字段2orderby字段3rowsnpreceding)LEECODE1321餐馆营业额变化增长表:Customer+---------------+---------+|Colum......
  • 使用MySQL驱动方式实现读写分离
    前言MySQL在5.1.X版本之后增加了对multi-host的支持,我们可以使用它来实现读写分离。正常的jdbc连接格式为jdbc:mysql://ip:3306/testdb?characterEncoding=UTF-8multi-host的jdbc连接格式为jdbc:mysql:replication://ip:3306,ip:3307,ip:3308/testdb?useUnicode=t......
  • Springboot计算机毕业设计财务报销微信小程序【附源码】开题+论文+mysql+程序+部署
    本系统(程序+源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景随着移动互联网技术的飞速发展,微信小程序作为一种新型的应用形态,以其便捷、高效的特点受到了广大用户的青睐。在高等教育领域,财务管理是学校运营中不......
  • Springboot计算机毕业设计博物馆预约小程序【附源码】开题+论文+mysql+程序+部署
    本系统(程序+源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景在信息化、数字化日益发展的今天,博物馆作为传承历史文化的重要场所,其管理和服务方式也在不断革新。传统的博物馆参观方式往往受限于开放时间、参观人......
  • 【SQL】数据定义语言(DDL):包括创建、修改和删除数据库对象
    数据定义语言(DDL)是用于定义和管理数据库中的数据结构和对象的SQL语言子集。它允许用户创建、修改和删除数据库中的表、索引、触发器、序列、存储过程等对象。DDL语句在数据库系统中执行时,通常会影响整个数据库的结构,而不是单个的数据记录。以下是DDL中一些常用语句的详细介绍......
  • 【数据库】MySQL数据库学习涵盖的多个方面
    数据库基础概念:数据库的概念和分类:了解什么是数据库以及常见的数据库类型。关系型数据库管理系统(RDBMS):理解RDBMS的概念及其在数据库管理中的作用。MySQL安装与配置:安装MySQL:学习如何在不同操作系统上安装MySQL数据库服务器。配置MySQL:包括设置root密码、配置网络连接、调整......
  • 探究MySQL8.0驱动的加载
    探究MySQL8.0驱动的加载大家在连接mysql的时候,启动项目,会警告你推荐使用com.mysql.cj.jdbc.Driver而不是com.mysql.jdbc.Driver那么这两者到底有什么区别呢本质区别:com.mysql.jdbc.Driver是mysql-connector-java5中的,需要手动加载驱动com.mysql.cj.jdbc.Driver是mysql......
  • 探究MySQL8.0驱动的加载
    探究MySQL8.0驱动的加载大家在连接mysql的时候,启动项目,会警告你推荐使用com.mysql.cj.jdbc.Driver而不是com.mysql.jdbc.Driver那么这两者到底有什么区别呢本质区别:com.mysql.jdbc.Driver是mysql-connector-java5中的,需要手动加载驱动com.mysql.cj.jdbc.Driver是mysql-......
  • AI编程005/ 逆向生成mysql的建表语句
    1/通过insertinto语句生成建表语句有些时候我们能获取到表的insert语句,但是没有表结构。我们可以借助AI工具,让其逆向生成mysql的建表语句。提示词如下:根据下面的SQL语句,逆向生存mysql的建表语句,每个字段都加上中文注释。'''INSERTINTOsys_user(user_id,dept_id,us......
  • 解决bad SQL grammar []; nested exception is java.sql.SQLSyntaxErrorException
    解决badSQLgrammar[];nestedexceptionisjava.sql.SQLSyntaxErrorException解决SpringBoot中MySQL数据库报错“BadSQLGrammar”的问题目录解决SpringBoot中MySQL数据库报错“BadSQLGrammar”的问题问题描述解决步骤解决方案结论附:MySql常用配置参数及使用场景......