【MySQL】MySQL中SQL执行流程

news2024/12/30 2:15:20

文章目录

  • 一、MySQL语句执行流程
    • 1.1、主要的原因有以下几点
    • 1.2、具体执行流程图如下
  • 二、存储引擎
  • 三、MySQL的架构与内部模块
  • 四、崩溃恢复时如何判断事务是否需要提交

一、MySQL语句执行流程

  • 连接器(Connector): 当客户端发送一个连接请求时,连接器负责接受并建立与MySQL服务器的连接。它进行身份验证、权限验证等操作,并为客户端分配一个会话(Session)。
  • 查询缓存(Query Cache): 在连接建立后,MySQL可以使用查询缓存来提高查询性能。查询缓存会检查当前查询是否已经被缓存过,如果是,则直接返回缓存的结果,避免了后续的查询处理。然而,由于查询缓存的效果受到多个因素的影响,如缓存的大小、查询的复杂性等,有时候禁用查询缓存可能会获得更好的性能。
  • 解析器(Parser): MySQL解析器接收到待执行的SQL语句后,进行语法解析和语义分析,生成相应的解析树。
  • 预处理器: 它会检查生成的解析树,解决解析器无法解析的语义。比如,它会检查表和列名是
    否存在,检查名字和别名,保证没有岐义。
  • 优化器(Optimizer): 在解析阶段完成后,优化器会分析查询语句,考虑索引、表的顺序、连接类型等因素,生成最优的查询执行计划。(比如有多个索引的情况下使用那个索引)
  • 执行计划: 比如多张表关联查询,先查询哪张表?在执行查询的时候可能用到哪些索引,实际上用到了什么索引?可以使用EXPLAIN select name from user where id=1:该语句查看执行计划
  • 执行引擎(Execution Engine): 执行引擎根据优化器生成的执行计划,负责实际的查询操作。它与存储引擎进行交互,从磁盘或内存中读取数据,并进行数据过滤、排序、连接等操作。
  • 存储引擎(Storage Engine): 存储引擎是MySQL的核心组件之一,负责实际的数据存储和访问操作。它根据执行引擎的请求,读取或写入数据,并返回相应的结果。
  • 返回结果: 执行引擎将查询的结果返回给客户端,客户端可以获取到查询结果集、受影响的行数或错误信息等。

这里需要注意的是在MySQL 8中,查询缓存功能已经被移除。在之前的MySQL版本中,查询缓存允许将查询结果缓存在内存中,以便在后续相同的查询请求中直接返回缓存结果,从而提高查询性能。

1.1、主要的原因有以下几点

  1. 高并发写入下的性能问题: 查询缓存需要对查询进行精确匹配,一旦查询发生变化,缓存就会失效。在高并发写入负载下,频繁的更新操作会导致大量查询缓存的失效,造成额外的开销和性能下降。这使得查询缓存在具有高写入负载的场景下效果有限。
  2. 内存资源消耗: 查询缓存需要占用大量内存来存储查询结果,特别是在具有大量查询和结果集的情况下。对于大型数据库系统来说,维护和管理查询缓存所需的内存资源会占用宝贵的系统资源,可能导致内存不足和性能下降。
  3. 不一致性和复杂性: 查询缓存的存在可能导致数据不一致性的问题。当数据库中的数据发生变化时,缓存的查询结果可能仍然返回旧的结果,而不是最新的数据。此外,查询缓存的复杂性和维护成本也是考虑因素之一。

1.2、具体执行流程图如下

在这里插入图片描述

二、存储引擎

存储引擎(Storage Engine)是数据库管理系统(DBMS)中负责数据存储和访问的组件。它负责将数据持久化到磁盘上,并提供数据的读取、写入、更新和删除等操作。

在MySQL中,存储引擎是可插拔的,这意味着可以根据需求选择适合的存储引擎来管理数据。MySQL提供了多种存储引擎,每个存储引擎都有其独特的特点、性能特征和适用场景。

以下是一些常见的MySQL存储引擎:

  1. InnoDB: InnoDB是MySQL的默认存储引擎,它支持事务、行级锁定和外键约束等特性。InnoDB通过使用多版本并发控制(MVCC)来提供高度并发性和数据完整性。
  2. MyISAM: MyISAM是MySQL的另一个常见存储引擎,它不支持事务和行级锁定。MyISAM适合于读写比例低、对并发性要求不高的应用场景。它具有较高的插入和查询速度。
  3. Memory: Memory(也称为Heap)存储引擎将所有数据保存在内存中,适用于对速度要求极高的临时表和缓存等场景。但是,由于数据存储在内存中,数据库重启后数据将丢失。
  4. Archive: Archive存储引擎适用于存储大量历史数据和归档数据。它以高压缩率存储数据,但不支持索引,只能进行顺序读取。
  5. CSV: CSV存储引擎将数据存储在逗号分隔值(CSV)格式的文件中,适合于导入和导出数据。
  6. NDB Cluster: NDB Cluster存储引擎是一个分布式存储引擎,用于构建高可用性和可伸缩性的集群。它具有高度的冗余和故障转移能力。

具体如何选择这存储引擎就需要根据自己的业务来选择,一般情况下我们都使用的是InnoDB

三、MySQL的架构与内部模块

在这里插入图片描述

四、崩溃恢复时如何判断事务是否需要提交

  1. binlog无记录,redolog无记录:在redolog写之前crash,恢复操作:回滚事务

  2. binlog无记录,redolog状态prepare:在binlog写完之前的crash,恢复操作:回滚事务

  3. binlog有记录,redolog状态prepare:在binlog写完提交事务之前的crash,恢复操作:提交事务

  4. binlog有记录,redolog状态commit:正常完成的事务,不需要恢复

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

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

相关文章

设计模式学习之观察者模式

设计模式系列往期文章 设计模式学习之策略模式设计模式学习之策略模式在前端的应用设计模式学习之简单工厂模式设计模式学习之工厂方法模式设计模式学习之抽象工厂模式设计模式学习之策略模式和简单工厂模式的对比 这是设计模式系列的第7篇文章,在这之前我们已经介…

React函数式组件

1. 创建函数式组件 我们可以通过所定义的函数来进行react中组件的定义。首先我们可以定义一个函数,然后通过函数的返回值来进行相关组件的定义。例如下面这张写法,我们可以通过调用一个函数,通过其返回值来进行相关的操作。 function Test()…

chatgpt赋能python:Python遍历A到Z:SEO优化的关键

Python遍历A到Z:SEO优化的关键 对于任何一家网站来说,SEO (Search Engine Optimization, 搜索引擎优化)都是至关重要的,特别是在当今数字时代,人们常常会在搜索引擎中查找信息并浏览不同网站。其中一个重要的SEO策略是为每个网站…

笔记本安装双系统ubuntu时踩的坑——戴尔

如果你遇到以下的这些问题,不要直接装了,无解!!! 建议看我另一篇教程,把硬盘取出来在另外的电脑上装好系统再放回去,这样嘎嘎快。 移动硬盘中安装Ubuntu 20.04系统——立省99%的问题_放风筝的…

水质监测的重要性及应用

水质监测是保障水环境安全和人民健康的重要手段。随着城市化进程的加速和工业化程度的提高,水污染问题日益严重,水质监测的重要性也越来越凸显。水质监测是指对水体中的各种物理、化学和生物参数进行监测和分析,以评估水体的质量和污染程度。…

概率论--随机事件与概率--贝叶斯公式--随机变量

目录 随机事件与概率 概念 为什么要学习概率论 随机事件与随机事件概率 随机事件 随机事件概率 贝叶斯公式 概念 条件概率 概率乘法公式 贝叶斯公式 举个栗子 随机变量 随机变量的定义 随机变量的分类 离散型随机变量 连续型随机变量 随机事件与概率 概念 …

和Git相关的一些问题

1. Git拉取项目的两种方式以及区别 方式 Http:通过http方式的clone项目,不需要在git上手动绑定ssh,只需要在clone的时候输入账号,密码即可;SSH:通过ssh方式clone项目,需要手动绑定ssh密钥 区别 …

Linux——从零到精通

目录 前言: 一.Linux介绍 二.Linux基础命令 三.链接和文章从零到实战 基本信息介绍 Linux 操作系统的诞生、发展和成长过程始终依赖着五个重要支柱: 桌面环境 Linux为什么象征着企鹅 命名与读法 前言: 本篇文章结合所有从零到精通 Linux…

如何在jupyter notebook 中添加虚拟环境

一&#xff0e;如何在jupyter notebook 中添加虚拟环境 假设在D:\tf_training\envTraining创建了名为env_training的虚拟环境。 1.安装IPykernel < python2 > pip install ipykernel < python3 > pip install ipykernel 说明&#xff1a;最好进入到虚拟环境…

STM32单片机(九)USART串口----第九节:STLINK Utility

❤️ 专栏简介&#xff1a;本专栏记录了从零学习单片机的过程&#xff0c;其中包括51单片机和STM32单片机两部分&#xff1b;建议先学习51单片机&#xff0c;其是STM32等高级单片机的基础&#xff1b;这样再学习STM32时才能融会贯通。 ☀️ 专栏适用人群 &#xff1a;适用于想要…

第24天-订单服务(订单确认、订单接口幂等、订单验价、锁定库存)

f# 1.Docker安装RabbitMQ docker run -d --name rabbitmq \ -p 5672:5672 -p 25672:25672 -p 15672:15672 \ -e RABBITMQ_DEFAULT_USERadmin -e RABBITMQ_DEFAULT_PASSadmin \ --restartalways \ rabbitmq:management5672&#xff1a;AMQP端口25672&#xff1a;集群端口15672&…

和Cookie相关的一些问题

目录 1. Cookie储存在哪里&#xff1f; 2. 不同网站可以互相访问对方的Cookie吗&#xff1f; 3.二级域名能够读到一级域名的Cookie吗&#xff1f; 1. Cookie储存在哪里&#xff1f; Cookie是前后端共享的&#xff0c;故肯定是存在浏览器的。 在浏览器开发者工具中可以找到C…

### 4.1 Hadoop生态系统

狭义的Hadoop VS 广义的Hadoop 广义的Hadoop&#xff1a;指的是Hadoop生态系统&#xff0c;Hadoop生态系统是一个很庞大的概念&#xff0c;hadoop是其中最重要最基础的一个部分&#xff0c;生态系统中每一子系统只解决某一个特定的问题域&#xff08;甚至可能更窄&#xff09;…

UE5.2 Mobile安卓游戏 Graphics Profile工具使用总结

Android Graphics Profile工具 Android游戏Profile 图形帧的常用工具有: snapdragon profiler, renderdoc, 手机游戏APP环境 (1)opengl es3.1/3.2或者vulkan (2)UE5 Android 打Debug包 (3)USB连接电脑的设置: 手机连接电脑&#xff0c;开启USB传输文件模式&#xff0c;开…

全志V3S嵌入式驱动开发(解决32M spi-nor无法复位问题)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 之前制作spi-nor image的时候&#xff0c;就发现v3s存在无法复位的问题。只要进入linux之后&#xff0c;不管是console输入reboot指令&#xff0c;…

【C/C++解决读者-写者问题】

目录 一、问题描述二、问题分析三、三种策略实现1.读者优先策略2. 读写公平策略3.写者优先策略&#xff08;后续更新&#xff09; 一、问题描述 有读者和写者两组并发进程&#xff0c;共享一个文件&#xff0c;当两个或两个以上的读进程&#xff08;只是读数据&#xff0c;不会…

将数据转化为创新机会:8 种业务分析模型指南

当我们想要创新时&#xff0c;往往需要有实际的依据来支撑我们的想法。商业咨询顾问通常被认为是聪明的人&#xff0c;他们拥有模型化的分析思维&#xff0c;这种思维方式可以帮助他们更好地理解市场、竞争对手和客户需求。商业分析思维是一种系统性的思考方式&#xff0c;它可…

力扣 222. 完全二叉树的节点个数

题目来源&#xff1a;https://leetcode.cn/problems/count-complete-tree-nodes/description/ C题解1&#xff1a;层序遍历计算节点。 时间复杂度&#xff1a;O(n)空间复杂度&#xff1a;O(n) /*** Definition for a binary tree node.* struct TreeNode {* int val;* …

已开源!网易云信的热点探测平台实践

背景 对于一个互联网平台&#xff0c;特别是 toB 的 PaaS/SaaS 平台&#xff0c;热点 key 是一个绕不过去的问题。作为一个开放的系统&#xff0c;平台每天要承载来自大量的外部系统或者海量终端的请求&#xff0c;虽然所有的请求都需要满足开放平台定义好的鉴权规则&#xff0…

虚幻引擎(UE5)-大世界分区WorldPartition教程(四)

文章目录 前言一、Data Layers的使用1.添加Actor到Data Layers2.运行时处理 总结 上一篇&#xff1a;虚幻引擎(UE5)-大世界分区WorldPartition教程(三) 前言 Data Layers&#xff08;UE4中叫Layers&#xff09;用于将Actor划分到不同的Layer中&#xff0c;通过在编辑器和运行…