sql的执行流程

执行过程分成两层,一层是server层,主要进行连接服务,和分析语句,执行sql

具体流程是 首先与用户通过连接器建立连接,然后将sql查询语句在查询缓存中查找,如果查找处理过相同的语句将,直接返回数据,给连接器,进而返回给用户,如果没有查到,则将sql语句发送给解析器,解析器中有词法分析和语法分析,通过这两个分析过程,创建对应的sql语法树,然后执行sql查询语句流程,首先经过预处理,优化器,执行计划,最后通过执行器,建立和存储引擎的连接

第二层是存储引擎层,当通过执行器将处理好的sql语句传到innodb引擎后,进行引擎内部的处理,最后返回查询结果,给执行器你,执行器将返回的记录发送给连接器。

具体分析每一个步骤都做了什么

连接器

首先执行 mysql -h -u -p 连接服务,连接过程需要经过TCP三次握手,因为Mysql是基于TCP协议进行传输的,建立完TCP连接后要开始验证用户名和密码,一个mysql服务可以被多个客户端连接,但是不是每个客户端都是一直请求服务的,但是如果长时间保持这个客户端的连接,会占用资源,mysql设置了最长的空闲链接保持时间,就是八小时,也可以手动关闭空闲连接使用 kill connection + id 的方式,mysql的连接数量也有限制,默认为最大连接数量是151 ,mysql的连接和http一样都有长短连接之分,长链接的好处是可以减少建立连接和断开连接的过程,所以一般使用的是长链接,但是mysql在执行查询过程中临时使用内存管理连接对象,这些连接对象只有在断开连接才会释放,如果存在的长链接很多,则会导致mysql占据大量内存空间,解决这个问题,可以从两个方面入手,一定期断开长链接,二客户端主动重置连接

查询缓存

就是将之前执行的select语句查询的结果使用键值对的方式保存下来,键是sql语句,值是结果,但是这个缓存结果,会因为如果这个表中的数据更改了,就就会出发缓存清空

MySQL 8.0 版本直接将查询缓存删掉了,也就是说 MySQL 8.0 开始,执行一条 SQL 查询语句,不会再走到查询缓存这个阶段了。

对于 MySQL 8.0 之前的版本,如果想关闭查询缓存,我们可以通过将参数 query_cache_type 设置成 DEMAND。

解析SQL

在正式执行 SQL 查询语句之前, MySQL 会先对 SQL 语句做解析,这个工作交由「解析器」来完成。

解析器

由两部分组成

词法分析器:

mysql会根据输入的字符串识别出关键字出来,例如sql语句 select username from userinfo ,在分析之后,会得到四个token,其中两个keyword,分别是select ,from

语法分析:

语法分析。根据词法分析的结果,语法解析器会根据语法规则,判断你输入的这个 SQL 语句是否满足 MySQL 语法,如果没问题就会构建出 SQL 语法树,这样方便后面模块获取 SQL 类型、表名、字段名、 where 条件等等

执行SQL

执行sql主要分成 ,预处理阶段,优化阶段,执行阶段

预处理器

1.检查sql查询语句中的表或者字段是否存在

2.将select * 中的*符号,扩展为表上的所有列;

优化器

经过预处理阶段后,还需要为sql查询语句先指定一个执行计划,优化器就是用来完成这个的。

优化器主要负责将sql查询语句的执行方案确定下来,比如表里面有多个索引的时候,优化器会基于查询成本的考虑,来决定使用那个索引。

执行器

经历完优化器后,就确定了 执行方案,接下来mysql就真正开始执行语句了,这个工作是有执行器完成。在执行的过程中,执行器就会和存储引擎交互,交互是以记录为单位的。

总得来说一条查询语句的执行过程可以这样讲:首先连接器和客户端建立连接,连接的建立就是使用的tcp建立连接,三次握手,然后使用的是长链接的方式建立连接,为了避免长链接带来的长期占用内存资源问题,使用定期断开连接的方式和客户端主动重置连接的方式,空闲连接最多保持8个小时,最多可以连接151个。然后如果是select语句则还会经过查缓存的方式,查看缓存中是否有保存的数据,查缓存在mysql8.0后取出了,因为没啥用。然后就是执行分析器,分析器首先进行词法分析,就是找出语句中使用的关键字,然后进行语法分析,就是利用词法分析的结果构建语法树,方便后面进行模块化处理。然后就进入了执行sql过程,执行sql过程分为三个部分,预处理部分,就是将select中的*号变成列中的所有表名和检查sql查询语句中的表明是否都存在,接着进入优化器阶段,优化器会根据语句中的情况,选择代价最小的方式执行语句,比如选择合适的键进行索引查询,最后到了执行阶段,根据执行计划执行 SQL 查询语句,从存储引擎读取记录,返回给客户端

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

用uniapp 及socket.io做一个简单聊天app 2

在这里只有群聊,二个好友聊天,可以认为是建了一个二人的群聊。 const express require(express); const http require(http); const socketIo require(socket.io); const cors require(cors); // 引入 cors 中间件const app express(); const serv…

Nginx 如何处理请求的流量削峰?

🍅关注博主🎗️ 带你畅游技术世界,不错过每一次成长机会! 文章目录 Nginx 如何处理请求的流量削峰?一、什么是流量削峰二、Nginx 实现流量削峰的基本原理(一)反向代理与负载均衡(二&…

微服务实战系列之玩转Docker(五)

前言 在我们日常的工作生活中,经常听到的一句话:“是骡子是马拉出来遛遛”。目的是看一个人/物是不是名副其实。我们在使用docker时,也要看看它究竟是如何RUN起来的。当面试官问你的时候,可以如是回答,保你“一文通关…

【python】OpenCV—Open URL Images

文章目录 1、需求描述2、方法一,numpyurlopen3、方法二,scikit-learn4、涉及到的库urllib.request.urlopenskimage.io.imread 5、参考文章 1、需求描述 给出一个 url 链接,显示该链接对应的图片 2、方法一,numpyurlopen # 导入…

Linux应用——socket函数及TCP通信

网络通信实质上也是实现进程间通信,只是与之前进程间通信不同的是,现在在不同的计算机上进行进程间通信。比如:利用QQ工具实现聊天,在两个电脑上有不同的QQ进程之间在通信。而网络通信是如何使用进程间通信呢?采用的是…

力扣高频SQL 50 题(基础版)第一题

文章目录 力扣高频SQL 50 题(基础版)第一题1757.可回收且低脂的产品题目说明思路分析实现过程准备数据:实现方式:结果截图: 力扣高频SQL 50 题(基础版)第一题 1757.可回收且低脂的产品 题目说…

pdf2docx - pdf 提取内容转 docx

文章目录 一、关于 pdf2docx主要功能限制 二、安装1、 PyPI2、从remote安装3、从源码安装4、卸载 三、转化 PDF例 1: convert all pages例 2: 转换指定页面例 3: multi-Processing例 4: 转换加密的pdf 四、提取表格五、命令行交互1、按页面范围2、按页码3、Multi-Processing 六…

Java之集合底层-数据结构

Java集合之数据结构 1 概述 数据结构是计算机科学中研究数据组织、存储和操作的一门学科。它涉及了如何组织和存储数据以及如何设计和实现不同的数据操作算法和技术。常见的据结构有线性数据结构(含数组、链表、栈和队列等),非线性数据结构…

探索算法系列 - 双指针

目录 移动零(原题链接) 复写零(原题链接) 快乐数(原题链接) 盛最多水的容器(原题链接) 有效三角形的个数(原题链接) 查找总价格为目标值的两个商品&…

数据库表结构创建

一、原型图 二、分析 1、天气,值字段只有实测值,可用一个字段表示(单位、来源同上) 2、气温有默认值与实测值两个选项,一个字段无法表示默认值与实测值(单位,来源同上) 3、因为有…

SpringMVC 控制层框架-下

五、SpringMVC其他扩展 1. 异常处理机制 1.1 异常处理概念 开发过程中是不可避免地会出现各种异常情况,例如网络连接异常、数据格式异常、空指针异常等等。异常的出现可能导致程序的运行出现问题,甚至直接导致程序崩溃。因此,在开发过程中&a…

LoFTR关键点特征匹配算法环境构建与图像匹配测试Demo

0,LoFTR CVPR 2021论文《LoFTR: Detector-Free Local Feature Matching with Transformers》开源代码 1,项目主页 LoFTR: Detector-Free Local Feature Matching with Transformers 2,GItHub主页 GitHub - zju3dv/LoFTR: Code for "…

Vue 状态管理 Vue CLI

Vue 状态管理 & Vue CLI 1、状态管理2、集中状态管理2.1 Vuex2.1.1 Vuex核心概念2.1.2 Vuex Store实例2.1.3 Vuex Getter2.1.4 Vuex Mutation2.1.4 Vuex Actions2.1.4 Vuex Module 2.2 Pinia2.2.1功能增强 3、Vuex 实现原理4、Pinia 实现原理5、CLI5.1 实现 1、状态管理 将…

vue 搜索框

效果 创建搜索组件: 在Vue项目中,首先需要创建一个搜索组件。这个组件通常包含一个输入框和一个搜索按钮。使用v-model指令将输入框与组件的数据属性(如searchKeyword)进行双向绑定,以便获取用户输入的关键词。处理搜索…

MongoDB教程(二十一):MongoDB大文件存储GridFS

💝💝💝首先,欢迎各位来到我的博客,很高兴能够在这里和您见面!希望您在这里不仅可以有所收获,同时也能感受到一份轻松欢乐的氛围,祝你生活愉快! 文章目录 引言一、GridFS…

科技云报道:算网筑基AI注智,中国联通如何讲出AI时代的“新故事”?

科技云报道原创。 AI从未停止进化,也从未停止给人类带来惊喜。 从ChatGPT代表的文生文、Dall-E代表的文生图,到Sora代表的文生视频,Suno为代表的文生音乐,生成式AI的“暴力美学”持续突破内容生产的天花板,大模型技术…

【LLM】-07-提示工程-聊天机器人

目录 1、给定身份 1.1、基础代码 1.2、聊天机器人 2、构建上下文 3、订餐机器人 3.1、窗口可视化 3.2、构建机器人 3.3、创建JSON摘要 利用会话形式,与具有个性化特性(或专门为特定任务或行为设计)的聊天机器人进行深度对话。 在 Ch…

vue import from

vue import from 导入文件,从XXXX路径;引入文件 import xxxx from “./minins/resize” import xxxx from “./minins/resize.js” vue.config.js 定义 : resolve(src);就是指src 目录 import xxxx from “/utils/auth” im…

新版GPT-4omini上线!快!真TM快!

大半夜,OpenAI突然推出了GPT-4o mini版本。 当我看到这条消息时,正准备去睡觉。mini版本质上是GPT-4o模型的精简版本,没有什么革命性的创新,因此我并没有太在意。 结果今天早上一觉醒来发现伴随GPT-4o mini上线,官网和…

RAS--APEI 报错解析流程(2)

RAS--APEI 报错解析流程(1) 除了APEI 中除了GHES会记录错误,在Post过程中的错误通常是通过BERT Table汇报 1.BERT Boot Error Record Table is used to report unhandled errors that occurred in a previous boot,it is reported as a ‘one-time polle…