博客
关于我
MySQL语句执行过程
阅读量:425 次
发布时间:2019-03-06

本文共 690 字,大约阅读时间需要 2 分钟。

目录

平常我们看到的只是一条语句执行出来的结果,并不知道中间发生了什么,今天就来探究一下,MySQL语句的执行过程。

1.连接器

每次使用Mysql会先连接到数据库上面,连接器负责跟客户端进行连接

mysql -u root -p

然后根据密码,判断我登陆进去会有什么权限,并分配权限给我

通过 show processlist可以查看客户端连接的状态

2.查询缓存

当连接建立完成之后,MySQL会对所执行的查询语句进行查询,有没有在缓存中,如果有直接返回缓存的查询结果,不需要执行下一步了。

当语句不存在缓存中,通过分析器继续分析。

不建议使用查询缓存,因为表的数据的更改都会使缓存失效,适合用查询缓存的表,比如经常不用更改的数据,还有静态数据。如果硬要走缓存可以显示指定SQL_CACHE

select SQL_CACHE * from Student where ID=1;

3.分析器

分析器会将sql语句识别,关键字识别,每一个单词代表什么,然后会根据这些识别能否满足SQL语法,满足不了会提示你哪部分错误。比如你一个单词输入错误,分析器会将错误直接提示出来。

4.优化器

优化器是用来决定表的索引使用,以及表的连接顺序等等,来达到最快的速度。

5.执行器

当优化完成之后,执行器开始执行SQL语句,当权限不足的时候会提示错误。执行器根据表的引擎获取接口。

对数据一行行进行判断,直到表的最后一行,最后把结果集返回给客户端。SQL语句到这里就执行完成了

在Mysql中有一个慢查询日志,有一个读取行的记录字段rows_examined ,这个就是读取每行时累加的数据。

转载地址:http://kyakz.baihongyu.com/

你可能感兴趣的文章
Mysql中存储引擎简介、修改、查询、选择
查看>>
Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>
mysql中实现rownum,对结果进行排序
查看>>
mysql中对于数据库的基本操作
查看>>
Mysql中常用函数的使用示例
查看>>
MySql中怎样使用case-when实现判断查询结果返回
查看>>
Mysql中怎样使用update更新某列的数据减去指定值
查看>>
Mysql中怎样设置指定ip远程访问连接
查看>>
mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
查看>>
Mysql中文乱码问题完美解决方案
查看>>
mysql中的 +号 和 CONCAT(str1,str2,...)
查看>>
Mysql中的 IFNULL 函数的详解
查看>>
mysql中的collate关键字是什么意思?
查看>>
MySql中的concat()相关函数
查看>>
mysql中的concat函数,concat_ws函数,concat_group函数之间的区别
查看>>
MySQL中的count函数
查看>>
MySQL中的DB、DBMS、SQL
查看>>
MySQL中的DECIMAL类型:MYSQL_TYPE_DECIMAL与MYSQL_TYPE_NEWDECIMAL详解
查看>>
MySQL中的GROUP_CONCAT()函数详解与实战应用
查看>>
MySQL中的IO问题分析与优化
查看>>