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为我们记录执行流程

详见

 

Mysql查询语句执行过程的更多相关文章

  1. MySQL查询语句执行过程及性能优化(JOIN/ORDER BY)-图

    http://blog.csdn.net/iefreer/article/details/12622097 MySQL查询语句执行过程及性能优化-查询过程及优化方法(JOIN/ORDER BY) 标签 ...

  2. MySQL查询语句执行过程及性能优化-查询过程及优化方法(JOIN/ORDER BY)

    在上一篇文章MySQL查询语句执行过程及性能优化-基本概念和EXPLAIN语句简介中介绍了EXPLAIN语句,并举了一个慢查询例子:

  3. [转]MySQL查询语句执行过程详解

    Mysql查询语句执行原理 数据库查询语句如何执行?语法分析:首先进行语法分析,对使用sql表示的查询进行语法分析,生成查询语法分析树.语义检查:检查sql中所涉及的对象以及是否在数据库中存在,用户是 ...

  4. MySQL查询语句执行过程及性能优化-基本概念和EXPLAIN语句简介

    网站或服务的性能关键点很大程度在于数据库的设计(假设你选择了合适的语言开发框架)以及如何查询数据上. 我们知道MySQL的性能优化方法,一般有建立索引.规避复杂联合查询.设置冗余字段.建立中间表.查询 ...

  5. 小觑数据库(SqlServer)查询语句执行过程

    近年来,越来越多的NoSql产品不断的以技术革命的者的身份跳出来:“你看哥是多么的快,你们关型型数据库真是战五渣阿”.是的,高性能的场景下NoSql真的很出彩.而我们关系型数据库只能在墙角哭泣&quo ...

  6. mysql中SQL执行过程详解与用于预处理语句的SQL语法

    mysql中SQL执行过程详解 客户端发送一条查询给服务器: 服务器先检查查询缓存,如果命中了缓存,则立刻返回存储在缓存中的结果.否则进入下一阶段. 服务器段进行SQL解析.预处理,在优化器生成对应的 ...

  7. python 3 mysql sql逻辑查询语句执行顺序

    python 3 mysql sql逻辑查询语句执行顺序 一 .SELECT语句关键字的定义顺序 SELECT DISTINCT <select_list> FROM <left_t ...

  8. MySQL 语句执行过程详解

    MySQL 原理篇 MySQL 索引机制 MySQL 体系结构及存储引擎 MySQL 语句执行过程详解 MySQL 执行计划详解 MySQL InnoDB 缓冲池 MySQL InnoDB 事务 My ...

  9. mysql第四篇--SQL逻辑查询语句执行顺序

    mysql第四篇--SQL逻辑查询语句执行顺序 一.SQL语句定义顺序 SELECT DISTINCT <select_list> FROM <left_table> < ...

随机推荐

  1. java实现第六届蓝桥杯显示二叉树

    显示二叉树 题目描述 排序二叉树的特征是: 某个节点的左子树的所有节点值都不大于本节点值. 某个节点的右子树的所有节点值都不小于本节点值. 为了能形象地观察二叉树的建立过程,小明写了一段程序来显示出二 ...

  2. Linux 文件系统属性chattr权限

    chattr命令 格式:chattr [+-=] [选项] 文件或目录名,其中,+表示增加权限,-表示删除权限,=表示等于某权限(对超级用户root也有用),比如:chattr +i /project ...

  3. iOS-Core Foundation框架到Foundation桥接的三种方式

    温故知新.勤总结,才能生巧!这次总结一下 :Core Foundation框架到Foundation桥接的三种方式 Foundation提供OC的基础类(像NSObject).基本数据类型等. Cor ...

  4. zabbix 大流量断图

    一. 环境介绍 系统版本:Centos7.4 zabbix-agent 版本:zabbix-agent 3.4.7   二. 问题现象 在使用zabbix的snmp方式的监控端口流量时,某一个图总是断 ...

  5. SpringSceurity(4)---短信验证码功能实现

    SpringSceurity(4)---短信验证码功能实现 有关SpringSceurity系列之前有写文章 1.SpringSecurity(1)---认证+授权代码实现 2.SpringSecur ...

  6. MySQL数据库字符集和排序规则的四个级别

    MySQL数据库字符集和排序规则有四个级别的默认设置:服务器,数据库,表和列. 最初,服务器字符集和排序规则取决于启动mysqld时使用的选项.可以使用 --character-set-server该 ...

  7. 数值格式化 NumberFormat、 DecimalFormat、 RoundingMode

    NumberFormat [简介] java.text.NumberFormat extends java.text.Format extends java.lang.Object 实现的接口:Ser ...

  8. SpringCloud Alibaba (一):序言

    为什么要转用SpringCloud Alibaba? Spring Cloud Netflix项目进入维护模式 在2018年底时,Netflix宣布Hystrix进入维护模式.自2016年以来,Rib ...

  9. Linux服务器安装python3.6

    CentOS 7上默认安装的python版本是2.7.5,系统自带的旧版本python被系统很多其他软件环境依赖,因此不能卸载原Python,直接选择Python3.6.5进行全新安装. 1 安装Py ...

  10. 附017.Kubernetes_v1.17.4 Dashboard部署

    一 Kubernetes dashboard简介 1.1 Web UI简介 dashboard是基于Web的Kubernetes用户界面.可以使用dashboard将容器化应用程序部署到Kuberne ...