一条SQL语句是如何执行的?

article/2025/9/19 3:27:32

大家六一儿童节好呀!

 接下来的一段时间内,将带领大家一同探索MySQL的奥妙,加油吧!我们。

下面进入正题:一条SQL语句是如何进行的?

对于这个问题,我想将其分为两个问题来回答,分别是:

  • 一条查询SQL是如何执行的?
  • 一条更新SQL是如何执行的?

 我们都知道MySQL内部是分为Server层和存储引擎层的;每个层都有各自的职责;

 对于一个查询语句,eg:select * from T where ID=10

 第一步:连接器(负责跟客户端简历连接、获取权限、维持和管理连接)

mysql -h IP -p Prot -u User -p Password #密码错误会提醒“Access denied for user”

 如果验证通过,连接器会到表里面查出你拥有的权限;这个连接里面的权限判断逻辑,都依赖于此权限。

假如一个用户连接成功后,即使管理员账号对这个用户的权限进行了修改,也不会影响当前连接,除非重新建立连接。 

 完成后,如果你没有后续的动作,这个连接就处于空闲状态,可用“show processlist”命令查看。显示sleep则为空闲

 这里涉及到一个长连接和短连接

  •  长连接:建立连接成功后,如果客户端持续有请求,则一直使用同一个连接。
    • 会发现有些时候MySQL占用内存涨的特别快,这是因为MySQL在执行过程中临时使用的内存是管理在连接对象中的,连接断开即释放。现象举例:MySQL异常重启
      • 方案一:定期断开长连接
      • 方案二:每次执行一个比较大的操作后,执行"mysql_reset_connection"(此过程不会重新做权限验证)
  •   短连接:执行完很少的几次查询就断开连接

第二步:查询缓存 

  •  之前执行过的查询,MySQL以"Key - Value"的形式存在内存(key为SQL,value为结果集);
  • 只要对该表有一个更新,则这个表上的查询缓存都会被清空;
  • 手动创建命令:select SQL_CACHE * from T(MySQL8中已经彻底废除此功能);

第三步:分析器(词法分析 —— 语法分析) 

 词法分析:通过“select”,识别出为查询;通过“T”,识别出表名;通过条件“ID”,识别出ID那一列;等等;

 语法分析:如果语法有误,则提示“You have an error in your SQL syntax”; 

第四步:优化器

      决定用哪个索引;联查表连接顺序;条件执行优先级 ,等等; 

第五步:执行器 (执行SQL)

第六步:存储引擎(提供读写接口,供执行器调用并获取结果集) 

  •  首先会判断你是否有该权限;
  • 如果命中查询缓存,则会在返回结果的时候进行权限验证;

补充:MySQL慢查询日志中,会有一个rows_examined字段,代表扫描了多少行。这个值就是在每次调用存储引擎获取数据行的时候累加的。不过,若是只调用一次,而扫描了多行,则rows_examined是不准确的。

 

 对于一条更新SQL,同样走和查询一样的流程。

不过,执行更新SQL会涉及到两个重要的日志:redo log (重做日志)、bin log (归档日志)。 

“《孔乙己》中,酒店掌柜有一个粉板,专门用来记录客人的赊账记录,如果赊账的人不多,那么他可以把顾客名和账目写在粉板上。但如果赊账太多了,粉板总有挤不下的时候,这个时候,掌柜一定还有一个专门记账的账本”

掌柜第一种做法:每次记账都打开账本

掌柜第二种做法:先写在粉板上,打烊后再核算

个人感觉掌柜很聪明。对于MySQL,同样也有类似的处理: 

  •  MySQL的  WAL技术,(Write-Ahead-Logging),先写日志,再写磁盘。
  • 对于innodb,会先把记录写到redo log中,并更新内存,同时,innodb会在适当的时候,将这个操作记录更新到磁盘中
  • 有了redo log 会保证innodb在数据库发生异常重启之后,之前提交的记录都不会丢失,称之为:“crash_safe”

 redo log是存储引擎层的日志,bin log是server层的日志

redo logbin log
innodb独有server层日志,所有引擎都有
物理日志,记录“在某个数据页上做了什么修改”逻辑日志,记录的是语句的原始逻辑
循环写,空间固定追加写入

 

以上就是执行一个SQL语句会经历的过程,当中提到的很多名词,后期会慢慢给出对应详细解释,大家也可以提出来。

努力吧!坚持做正确的事!相信自己!!! 


http://chatgpt.dhexx.cn/article/ISliN2A2.shtml

相关文章

mysql 查看线程状态

show full PROCESSLIST 打开两个查询窗口,在A窗口执行一个查询时间较长的sql,在B窗口使用show full PROCESSLIST,可以看到A中执行的sql时间。 sleep表示没有操作,query表示正在查询。

线程状态总结

目录 文章目录 前言 一、线程状态图解 二、线程的几种状态 及线程过程 1.线程的几种状态 2.线程过程 总结 前言 总结了在华清远见这段时间所学的线程相关的知识点,文章记录了线程的几种状态及线程的过程 提示:以下是本篇文章正文内容,下面案…

线程状态

原文:https://mp.weixin.qq.com/s/GsxeFM7QWuR--Kbpb7At2w 人类为了利用好自己的时间,经常会同时做多件事情,比如上厕所时刷手机,开车时听新闻... 对于自己尚且如此,对计算机也不能闲着。为了最大化的提升机器利用率&…

一条SQL语句的执行过程

摘要 本文站在后端开发的角度,讲述一条SQL从客户端发送到MySQL服务器进行处理,并将结果返回给客户端的过程。这个过程中涉及的操作会在后面的文章中做详细的分析。 连接建立 我们通常使用ORM框架来生成SQL语句,在发送SQL语句给MySQL服务器…

多线程执行sql报错处理

pymysql多线程访问数据库报错:Packet sequence number wrong - got 7 expected 2 原文:https://www.cnblogs.com/heiao10duan/p/9373237.html参考:https://www.jianshu.com/p/60c8e0e440ea原因: 使用了多线程,多线程共…

MySQL - 一条 SQL 语句是如何执行的(SQL执行详解)

前言 天天和数据库打交道,一天能写上几十条 SQL 语句,但你知道我们的系统是如何和数据库交互的吗?MySQL 如何帮我们存储数据、又是如何帮我们管理事务?....是不是感觉真的除了写几个 「select * from dual」外基本脑子一片空白&a…

一、SQL语句执行过程

一、MySQL架构图 MySQL逻辑架构图,可以分为 Server 层和存储引擎层两部分。 Server 层包括连接器、查询缓存、分析器、优化器、执行器等,涵盖 MySQL 的大多数核心服务功能,以及所有的内置函数(如日期、时间、数学和加密函数等&…

线程状态详解

线程的生命周期 new的时候即为创建状态。 调用start即为启动了,启动线程后就变为就绪状态, 就绪之后等待CPU的调度,CPU调度完之后,就进入了运行状态。 运行状态运行sleep方法时会进入阻塞状态,进入阻塞状态有非常多…

一条 SQL 语句是如何执行的

1. select 语句执行过程 一条 select 语句的执行过程如上图所示 1、建立连接 连接器会校验你输入的用户名和密码是否正确,如果错误会返回提示,如果正确,连接器会查询当前用户对于的权限。连接器的作用就是校验用户权限 2、查询缓存 MySQL…

SQL线程状态分析:processlist

老哥哔哔叨 我们已经写了很多 MySQL 的文章了,比如索引优化、数据库锁、主从复制等等。今天在来和大家学习一个优化方法:show processlist——查看当前所有数据库连接的 session 状态。帮助我们查看每个 SQL 线程的运行状态,是运行正常呀&…

线程的状态

1、线程有5种状态:新建(new Thread)、就绪(runnable),运行(running)、阻塞(blocked)、结束(dead) 主要方法: setPriorit…

基于TCP和HTTP协议的RPC简单实现

一、RPC基本概念 1、基本概念 (1)RPC(Remote Procedure Call Protocol)——远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议; (2&…

RPC协议及常用框架

https://www.jianshu.com/p/8ba4b7b834aa RPC协议 RPC:远程过程调用,原则上来说系统间跨进程的调用都属于RPC范畴 RMI/HTTP/dubbo/Spring Cloud/thrift RPC框架如何实现分布式环境下的远程调用 在一个典型的RPC的使用场景中,包含了服务发现&#xf…

【RPC】RPC基础(二)RPC协议

文章目录 RPC核心原理1. RPC基础1.2 RPC协议为什么设计RPC协议如何设计RPC协议可扩展协议的设计思考 RPC核心原理 1. RPC基础 1.2 RPC协议 RPC协议和HTTP协议一样都属于应用层协议 协议的作用: ​ 协议就像是文章中的标点符号、段落格式等规定,有了…

Nodejs 之 RPC 协议简介

背景 随着 Nodejs 的兴起,越来越多的 Web 服务中间层被搭建起来。如 Node 服务端渲染,BFF(Backend For Frontend))层,而 RPC 是远端过程调用,经常用于 BFF 层。最近,我打算写一个中间层,用 Nodejs 调用 Go…

RPC协议底层原理与实现

RPC协议基本组成 在一个典型RPC的使用场景中,包含了服务发现、负载、容错、 网络传输 、 序列化 等组件,其中RPC协议就指明了程序如何进行网络传输和序列化 。也就是说一个RPC协议的实现就等于一个非透明的RPC调用,如何做到的的呢&#xff1f…

RPC详解

RPC是什么 RPC(Remote Procedure Call)远程过程调用协议,一种通过网络从远程计算机上请求服务,而不需要了解底层网络技术的协议。RPC它假定某些协议的存在,例如TPC/UDP等,为通信程序之间携带信息数据。在O…

深入理解RPC—协议

协议 一提到协议,你最先想到的可能是 TCP 协议、UDP 协议等等,并且这些网络传输协议的实现有点晦涩难懂。虽然在 RPC 中我们也会用到这些协议,但这些协议更多的是对我们上层应用是透明的,我们 RPC 在使用过程中并不太需要关注他们…

浅谈RPC协议

RPC协议 RPC简介为啥需要RPCRPC的调用过程gRPCProtoBuffergRPC实战 RPC简介 RPC(Remote Procedure Call Protocol)远程过程调用协议,目标就是让远程服务调用更加简单、透明。RPC 框架负责屏蔽底层的传输方式(TCP 或者 UDP&#x…

网络协议——RPC协议综述

拿最简单的场景,客户端调用一个加法函数,将两个整数加起来,返回它们的和。 如果放在本地调用,那是简单的不能再简单了,。但是一旦变成了远程调用,门槛一下子就上去了。 如何解决这五个问题? …