服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Mysql - MySQL:一条数据的存储之旅

MySQL:一条数据的存储之旅

2023-06-19 01:00未知服务器之家 Mysql

大家好,我是你们的小米,一个热爱技术分享的活泼小伙伴!今天,我来给大家揭开一个神秘的面纱,带你们深入了解一下MySQL数据库是如何保存一条数据的。 客户端 首先,让我们从客户端(Client)开始。当你在应用程序中执行一

大家好,我是你们的小米,一个热爱技术分享的活泼小伙伴!今天,我来给大家揭开一个神秘的面纱,带你们深入了解一下MySQL数据库是如何保存一条数据的。

客户端

首先,让我们从客户端(Client)开始。当你在应用程序中执行一个插入操作时,客户端就会发送一个SQL语句给MySQL服务器,告诉它你想要插入什么样的数据。

服务端

接下来,我们来看看服务器端(Server)。当MySQL服务器接收到来自客户端的SQL语句时,它会进行一系列的处理。

  • 首先,连接器(Connector)负责与客户端建立连接。它会验证你的身份信息,并且为你分配一个线程来处理你的请求。
  • 连接建立好之后,分析器(Parser)就开始发挥作用了。分析器会将你发送过来的SQL语句进行解析,拆分成一组词法单元,也就是我们所说的Token。

词法分析(Lexical Analysis)是分析器的第一步,它会将SQL语句中的每个字符进行扫描,识别出关键字、标识符、常量等。这个过程将SQL语句转换成一系列的Token,每个Token都有自己的类型和值。

  • 在词法分析之后,语法分析器(Syntax Analysis))会根据语法规则检查Token之间的关系,并构建一棵抽象语法树(AST)。抽象语法树表示了SQL语句的结构,方便后续的处理。

  • 抽象语法树(Abstract Syntax Tree)是一种树状结构,它以语法规则为基础,将SQL语句的各个部分组织起来。每个节点代表一个语法结构,比如SELECT语句、FROM子句等。

  • 在抽象语法树中,每个节点都对应着一个Token。Token存储了SQL语句的具体信息,比如关键字、标识符、常量的类型和值。

  • 当抽象语法树构建完成后,MySQL的优化器(Optimizer)登场了。优化器会对查询进行优化,选择最优的执行计划。它可以根据表的统计信息、索引信息等来做出决策。

  • 成本优化器(CBO)是MySQL优化器的一种策略,它会根据查询的成本估计来选择最佳的执行计划。CBO会考虑许多因素,比如表的大小、索引的选择、IO成本等。

  • 规则优化器(RBO)是另一种优化器策略,它会根据一组预定义的规则来选择执行计划。RBO比较简单直观,但缺乏CBO的智能化和自适应能力。

  • 优化器选择好执行计划后,执行器(Executor)就开始工作了。执行器负责实际执行查询,并将结果返回给客户端。

存储引擎

最后,让我们来看看存储引擎(Storage Engine)。MySQL支持多种存储引擎,比如InnoDB、MyISAM等。存储引擎负责将数据存储到磁盘上。

当执行器需要插入一条数据时,它会将数据传递给存储引擎。存储引擎会将数据写入到对应的表中,同时确保数据的持久性和一致性。

总结

总结一下,一条数据在MySQL中保存的过程可以分为:客户端发送SQL语句,连接器建立连接,分析器解析SQL语句生成抽象语法树,优化器选择执行计划,执行器执行查询,存储引擎将数据写入磁盘。这个过程经历了多个组件的协同工作,才能最终完成数据的保存。

MySQL:一条数据的存储之旅

延伸 · 阅读

精彩推荐
  • Mysqlmysql远程登录出错的解决方法

    mysql远程登录出错的解决方法

    mysql远程登录出错的情况,先比很多朋友都有遇到过吧,下面有个不错的解决方法,大家可以参考下 ...

    MYSQL教程网4882020-03-11
  • MysqlMySQL中随机生成固定长度字符串的方法

    MySQL中随机生成固定长度字符串的方法

    在MySQL中有时需要随机生成数字或字符串,随机生产数字可直接使用rand()函数,但是要随机生成字符串就比较麻烦。 ...

    mysql教程网9372019-11-12
  • MysqlMYSQL METADATA LOCK(MDL LOCK)MDL锁问题分析

    MYSQL METADATA LOCK(MDL LOCK)MDL锁问题分析

    这篇文章主要介绍了MYSQL METADATA LOCK(MDL LOCK)MDL锁问题分析,并通过实例给大家例句的问题处理办法,需要的朋友参考学习下。...

    MYSQL教程网4222020-08-23
  • MysqlMySQL8.0中的降序索引

    MySQL8.0中的降序索引

    这篇文章主要介绍了MySQL8.0中的降序索引的相关知识,帮助大家更好的理解和使用MySQL8.0的新特性,感兴趣的朋友可以了解下...

    brightdeng@DBA10252021-02-27
  • MysqlMySQL SQL语句优化的10条建议

    MySQL SQL语句优化的10条建议

    这篇文章主要介绍了MySQL中SQL语句优化需要注意的10点,,特别是大型高并发网站,需要的朋友可以参考下 ...

    MYSQL教程网3432020-03-19
  • Mysql一次神奇的MySQL死锁排查记录

    一次神奇的MySQL死锁排查记录

    这篇文章主要给大家介绍了一次神奇的MySQL死锁排查的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Mysql具有一定的参考学习价值,需...

    咖啡拿铁4422020-09-14
  • Mysql基于 Mysql 实现一个简易版搜索引擎

    基于 Mysql 实现一个简易版搜索引擎

    本文基于 Mysql 8.0 版本,数据库引擎采用的是 InnoDB,关于 Mysql 实现一个简易版搜索引擎,感兴趣的朋友可以参考下文...

    靓仔聊编程9902021-09-27
  • MysqlMySQL锁等待与死锁问题分析

    MySQL锁等待与死锁问题分析

    这篇文章主要介绍了MySQL锁等待与死锁问题分析,帮助大家更好的理解和学习使用MySQL,感兴趣的朋友可以了解下...

    MySQL技术12182021-04-30