首页 > 数据库 >SQL查询执行流程

SQL查询执行流程

时间:2024-03-27 18:01:47浏览次数:13  
标签:语句 缓存 流程 查询 SQL 权限 连接

在 MySQL 执行一条查询语句的时候,比如SELECT * FROM T WHRER ID = 1,这篇文章来简要的描述SQL查询的执行流程

可以把整体结构分成 Server 层和存储引擎层,Server 层包括连接器查询缓存器分析器优化器执行器。存储引擎层则有常见的 InnoDB,MyISAM,Menory 存储引擎,在 MySQL5.5 后默认使用 InnoDB 存储引擎

一、连接器

客户端连接到 MySQL 服务,连接器负责跟客户端建立连接,获取权限,维持和管理连接

  • 完成 TCP 三次握手,建立连接
  • 输入账号密码,验证身份,并获取用户权限

    这就意味着,一个用户成功建立连接后,即使修改了该用户的权限,也不影响已经存在的连接的权限,修改权限后,只有再新建连接才会使用最新的权限

  • 使用show processlist命令查看连接状态,默认连接保持 8 小时,可以使用wait_timeout来控制

二、查询缓存器

在建立连接后,就可以执行 SELECT 语句了,这时候会先查询缓存,查询缓存器会类似一个 K-V 的缓存,保存着查询语句和对应的返回结果,如果命中的话会直接返回

查询缓存的失效非常频繁,当表数据改变时,会清空所有的缓存数据

在 MySQL8 版本直接就把查询缓存器的整块功能给删除了

三、分析器

如果没有命中缓存的话,就要开始真正的执行语句了

词法分析:检查 SQL 语句拼写是否正确,例如语句中的 SELECT 写成 SELETC 系统就会提示拼写错误

语法分析:检查 SQL 语句是否满足语法要求,例如语句中没有写查询哪个表 系统会提示没指定表,表字段不存在等问题

四、优化器

通过分析器,MySQL 已经知道你要做什么了,但是在这之前还需要进行优化处理,比如:

  • 选择合适的索引
  • 多表 JOIN,对各个表的 JOIN 顺序进行优化
  • SQL 条件的等价替换

五、执行器

根据具体的执行计划,开始执行语句,开始执行的时候,先判断你对这个表是否有执行权限,如果没有则返回没有权限的错误,如果有权限则继续执行

比如这个查询语句: SELECT * FROM T WHRER ID = 1,这个 ID 字段没有索引,那么执行的顺序可能是这样的:

  1. 调用 InnoDB 引擎接口取这个表的第一行,判断 ID 值是不是 1,如果不是则跳过,如果是则将这行存在结果集中;
  2. 调用引擎接口取“下一行”,重复相同的判断逻辑,直到取到这个表的最后一行。
  3. 执行器将上述遍历过程中所有满足条件的行组成的记录集作为结果集返回给客户端。

参考:

  • 《MySQL45 讲》

我是一零贰肆,一个关注Java技术和记录生活的博主。

欢迎扫码关注“一零贰肆”的公众号,一起学习,共同进步,多看路,少踩坑。

标签:语句,缓存,流程,查询,SQL,权限,连接
From: https://www.cnblogs.com/sun2020/p/18099906

相关文章

  • Appointment(SQL注入)
    Appointment(SQL注入)1.TASK1问题:SQL的全称是?SQL是结构化查询语言的缩写。答案:StructuredQueryLanguage2.TASK2问题:最常见的一种SQL漏洞类型是什么?最常见的一种SQL漏洞类型为SQL注入漏洞答案:SQLinjection3.TASK3问题:OWASPtop10列表对注入漏洞的命名为什么?这个......
  • MySQL中的关键字和保留字
    MySQL中的关键字和保留字是用于特定任务的预定义名称,如定义数据结构、控制数据访问和执行其他操作。以下是MySQL中关键字和保留字的表格,但请注意,这个列表并不全面,因为MySQL版本更新可能会引入新的关键字或保留字,也可能弃用旧的关键字。分享内容直达2024最全大厂面试题无需......
  • 达梦开启慢查询
     1.修改参数文件[dmdba@localhostgproj]$moresqllog.iniBUF_TOTAL_SIZE=10240#SQLsLogBufferTotalSize(K)(1024~1024000)BUF_SIZE=1024#SQLsLogBufferSize(K)(50~409600)BUF_KEEP_CNT=6......
  • postgresql之创建dblink 以及查询写法和关闭dblink
    --启用dblink模块CREATEEXTENSIONdblink;--创建dblink连接--format:'dbname=mydbhost=myhostuser=myuserpassword=mypassword'--请替换mydb,myhost,myuser,和mypassword为实际的数据库名称、主机、用户和密码SELECTdblink_connect('dblink_name','dbname=......
  • Qt 操作sql server数据库
    Qt操作sqlserver数据库添加qtsql的库连接数据库QSqlDatabase_db=QSqlDatabase::addDatabase("QODBC");_db.setHostName();_db.setDatabaseName();_db.setUserName();_db.setPassword();_db.setPort();_db.open();增QSqlQueryquery;query.prepare("INSER......
  • sqlserver连接超时
    常规的连接超时,都是查看:网络是否联通防火墙是否关闭、tcp/ip协议是否启用、账号密码问题等。这种的基本上应用连不上数据库,但数据库管理器也肯定连不上。最近碰到2次特别现象就是应用连接数据库超时,但服务器上的数据库管理器连接是没问题的,数据库访问也正常。特此记录一下查了很......
  • Sql server 2019 文件夹共享方式异地备份遇到的问题
    1、无法找到路径'\\192.168.66.50\share_domain\2、该作业失败。 无法确定所有者WIN-DOAR3JOEG2C\Administrator(拥有作业Mofang异地差异备份.Subplan_1)是否有服务器访问权限(原因:无法获取有关WindowsNT组/用户'WIN-DOAR3JOEG2C\Administrator'的信息,错误代码0x54......
  • DM相关表结构查询
    --查询表名SELECTtable_nameFROMdba_tablesWHEREowner='所有者'ORDERBYtable_name--查询表注释SELECTT.table_name,U.COMMENTSAstable_commentFROMDBA_TABLESTJOINUSER_TAB_COMMENTSUONT.TABLE_NAME=U.TABLE_NAMEWHEREOWNER='所有者'ORDER......
  • RestCloud数据集成平台-监听SqlServer数据库表,并同步数据到MongoDB数据库表详细教程(实
    上一篇:RestCloud数据集成平台-Windows全量包安装部署详细教程1.数据源管理数据源主要用来建立与用户的数据库的链接。数据源管理主要用来对用户添加的所有数据链接进行管理,主要包括新建数据源、测试链接、修改链接、复制链接、查询链接和删除链接等功能。1.1.创建链接......
  • MySQL 中 CONCAT() 和 CONCAT_WS()用法
    CONCAT和CONCAT_WS都是MySQL中用于字符串连接的函数,但它们之间有一些区别:CONCAT函数:CONCAT函数用于连接两个或多个字符串。它接受任意数量的参数,将它们连接在一起并返回结果。如果其中有一个参数为NULL,则返回的结果也为NULL。例如:SELECTCONCAT('Hello','',......