返回顶部
首页 > 资讯 > 数据库 >Mysql查询语句执行过程 - G
  • 934
分享到

Mysql查询语句执行过程 - G

Mysql查询语句执行过程-G 2021-12-15 01:12:59 934人浏览 绘本
摘要

Mysql查询语句执行过程   mysql分为server层和存储引擎两部分,或许可以再加一层连接层   连接层(器) Mysql使用的是典型的C/S架构。连接器通过典型的tcp握手完成连接。 需要注的是, 如果用户名和密码都正确

Mysql查询语句执行过程 - G

Mysql查询语句执行过程

 

mysql分为server层存储引擎两部分,或许可以再加一层连接层

 

连接层(器)

Mysql使用的是典型的C/S架构。连接器通过典型的tcp握手完成连接。

需要注的是,

如果用户名和密码都正确,那么该连接所拥有的权限仅仅是连接成功建立时的所读取到的权限

这就意味着:当连接已经建立后,我们在对该用户的权限进行修改,这些修改要直到该用户再次建立连接时才会生效。

 

这听起来是个不好的设计,因为一旦建立连接,管理员是无法临时收回权限的。

索性,MySQL也想到了这一点,因此对于已经连接的空闲连接,在一定时间后会自动断开 --- 由参数wait_timeout控制,默认值是8小时。

我们可以使用

show processlist

查看已有连接是否处于空闲(Sleep)状态

想要使用示例数据库详见此处

我想,应该是为了用户权限的“稳定”才有了上面所谓的“不安全”的设计,因此使用DCL语句的时候要更加谨慎才行。

 

另外需要注意的是,

MySQL在执行过程中临时使用的内存是管理在连接对象中的

这就意味着,当我们连接一次然后不断通过该连接进行操作时(即使用长连接时),临时内存会不断积累,直到连接断开的时候才释放。但当内存占用过大,被系统杀掉(OOM --- Out of memory ),就会表现为MySQL异常关闭/重启。

为了避免这种状况我们可以使用两种规避方式:

  • 避免长连接,尽量使用短连接 --- 但建立连接其实是很耗时的
  • 使用MySQL5.7或者更高版本,可以通过mysql_reset_connection来初始化连接 --- 即在不重建连接的情况下释放临时内存(它是一个api方法,而不是直接在mysql shell中使用的命令,详见)

 

server层

就根据各个层次的名字一样,顾名思义,我们主要在在server层处理一条SQL语句,而这个过程在MySQL8.0版本后如下所示:

(连接器)>> 分析器 >> 优化器 >> 执行器
  • 分析器就是对SQL字符串的拆分与辨析

  • 优化器就是“择优”,即

    在表里有多个索引的时候选择使用哪个索引、在多表关联(join)的时候选择速度最快的join方式,如在进行如下查询时

    select * from t1 join t2 using(Id) where t1.a=10 and t2.b=20;
    

    优化器就会帮助我们选择是 “先选出t1.a=10的部分再关联t2” 还是 “先选出t2.b=20的部分再关联t1”

  • 执行器,

    开始执行 》 判断有没有相关权限 》使用表定义中的引擎 》 进行扫描执行语句
    

 

在8.0之前的版本还有“查询缓存”的机制,就是将查询过的结果放在缓存中以期望下次再次执行相同查询时能快速返回结果。但...哪里有那么多相同的查询呢,更过分的是这里的相同还要求表要没有发生改变,且语句的大小写都要相同。Are you serious ?于是弃之。

 

存储引擎

MySQL存储引擎负责存储和提取,其架构是插件式,支持(默认)InnoDB等多个存储引擎。

搜索引擎是针对表的,在create table 时可以使用engine = xxx来使用指定内存引擎。

 

让MySQL为我们记录执行流程

详见

 

您可能感兴趣的文档:

--结束END--

本文标题: Mysql查询语句执行过程 - G

本文链接: https://lsjlt.com/news/6822.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Mysql查询语句执行过程 - G
    Mysql查询语句执行过程   Mysql分为server层和存储引擎两部分,或许可以再加一层连接层   连接层(器) Mysql使用的是典型的C/S架构。连接器通过典型的TCP握手完成连接。 需要注的是, 如果用户名和密码都正确...
    99+
    2021-12-15
    Mysql查询语句执行过程 - G
  • MySQL执行一条查询语句的过程
      执行流程 如下图所示,我们可以看到当向 MySQL 发送一个请求时,MySQL 到底做了什么:   客户端发送一条査询给服务器。 服务器先检查査询缓存,如果命中了缓存,则立刻返回存储在缓存中的结果。否则进人下一阶段。 服务器端进...
    99+
    2018-04-18
    MySQL执行一条查询语句的过程
  • 详解MySQL 查询语句的执行过程
    首先先简单的将一个查询语句背后MySQL做了什么捋一捋: 客户端发送一条查询给服务器。 服务器先检查查询缓存,如果命中了缓存,则立刻返回存储在缓存中的结果。否则进入下一个阶段。 服务器端进行SQL解析,...
    99+
    2022-05-19
    MySQL 查询语句 MySQL 查询语句执行过程
  • SQL查询语句执行的过程
    目录MySQL基本架构Server 层1、连接器2、查询缓存3、分析器4、优化器5、执行器SQL语句举例: SELECT * FROM `test` WHERE `i...
    99+
    2024-04-02
  • MySQL查询语句的执行过程有哪些
    本篇文章为大家展示了MySQL查询语句的执行过程有哪些,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。查询请求的执行流程众所周知在MySQL数据库应用中查询请求是使用...
    99+
    2024-04-02
  • MySQL查询语句的执行过程是什么
    这篇文章主要介绍MySQL查询语句的执行过程是什么,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!首先先简单的将一个查询语句背后MySQL做了什么捋一捋:客户端发送一条查询给服务器。服务器先检查查询缓存,如果命中了缓存...
    99+
    2023-06-14
  • MySQL查询语句的执行过程实例分析
    这篇文章主要讲解了“MySQL查询语句的执行过程实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL查询语句的执行过程实例分析”吧!1、MYSQ...
    99+
    2024-04-02
  • 了解MySQL查询语句执行过程(5大组件)
    目录开篇查询请求的执行流程mysql组件定义连接器查询缓存分析器优化器逻辑变换代价优化执行器总结开篇 相信广大程序员朋友经常使用MySQL数据库作为书籍持久化的工具,我们最常使用的就是MySQL中的SQL语句,从客户端向...
    99+
    2022-08-14
    MySQL查询语句执行过程 MySQL组件
  • SQL查询语句执行的过程是什么
    这篇文章主要介绍“SQL查询语句执行的过程是什么”,在日常操作中,相信很多人在SQL查询语句执行的过程是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”SQL查询语句执行的过程是什么”的疑惑有所帮助!接下来...
    99+
    2023-06-30
  • MySQL SQL语句查询执行过程的阶段有哪些
    这篇文章将为大家详细讲解有关MySQL SQL语句查询执行过程的阶段有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 1.语法分析阶段:...
    99+
    2024-04-02
  • 一篇文章弄懂MySQL查询语句的执行过程
    前言 需要从数据库检索某些符合要求的数据,我们很容易写出 Select A B C FROM T WHERE ID = XX  这样的SQL,那么当我们向...
    99+
    2024-04-02
  • MySQL查询语句执行流程是什么
    这篇“MySQL查询语句执行流程是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“MySQL查询语句执行流程是什么”文章吧...
    99+
    2023-07-05
  • 【MySQL】如何查询MySQL执行过的所有SQL语句
    文章目录 1 MySQL 的通常查询日志实验2 参考资料 1 MySQL 的通常查询日志实验 通过 MySQL 的通用查询日志可以找到你指定的每一条 sql 语句。很明显会有严重的性能损耗...
    99+
    2023-09-22
    mysql 数据库
  • mysql中执行查询语句的流程分析
    这篇文章给大家分享的是有关mysql中执行查询语句的流程分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。比如,在我们从student表中查询一个id=2的信息selec ...
    99+
    2024-04-02
  • MySQL怎么执行联合查询语句
    在MySQL中,可以使用UNION关键字来执行联合查询语句。联合查询可以将多个SELECT语句的结果合并为一个结果集...
    99+
    2024-03-06
    MySQL
  • SQL查询语句执行原理
    首先有一个 user_info 表,表里有一个 id 字段,执行下面这条查询语句:select * from user_info where id = 1;返回结果为:mysql基本架构...
    99+
    2024-04-02
  • select查询语句该如何执行
    这期内容当中小编将会给大家带来有关select查询语句该如何执行,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。mysql 作为一个关系型数据库,在国内使用应该是...
    99+
    2024-04-02
  • MariaDB中怎么执行查询语句
    在MariaDB中执行查询语句可以使用以下步骤: 打开MariaDB命令行终端或者使用图形化界面工具连接到MariaDB数据库。...
    99+
    2024-04-09
    MariaDB
  • SQL语句的执行过程
    1.语法校验      如果在SQL计划缓存中没有对应的执行计划,服务器首先会对用户请求的SQL语句进行语法效验,如果有语法错误,服务器会结束查询操作,并用返回相应的错误信息给...
    99+
    2024-04-02
  • mysql查询语句中,是join先执行还是where先执行?
    在 MySQL 中,WHERE 子句会先于 JOIN 子句执行。 JOIN 子句用于连接两个或多个表,在 JOIN 子句中可以使用 ON 或 USING 子句来指定连接条件。 JOIN 子句会从两个表中返回符合连接条件的行,这些...
    99+
    2023-09-05
    mysql 数据库 sql mybatis
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作