SQL查询执行过程

MYSQL查询执行过程

  1. 客户端向服务器发送请求
  2. 服务器查询缓存,缓存中命中则结束,将结果返回客户端(返回前会检查用户权限),否则继续下边步骤
  3. 服务器端进行SQL解析、预处理,再由优化器生成对应的执行计划
  4. 根据执行计划调用存储引擎的API执行查询
  5. 将结果返回客户端

一、查询缓存

如果一条SQL语句以select开头,MySQL服务器将会尝试先在缓存中查询。每个cache都是以SQL文本做为key的,所以如果SQL语句中大小写不同也无法命中。

设置:my.cnf(Linuxe)/my.ini(Windows)

  1. query_cache_type=0时,不启用缓存查询
  2. query_cache_type=1时,启用缓存查询。如果在select后使用SQL_NO_CACHE,则本条SQL不使用缓存,对于查询很分散的SQL,不建议使用缓存,例如根据用户Id查询用户信息
  3. query_cache_type=2时,只对特定语句使用缓存。select后使用SQL_CACHE则进行缓存查询,对于接近静态数据的表,可以使用SQL_CACHE提高效率

命令:show variables like ‘%query_cache%‘查询缓存配置参数

命令:show status like ‘%Qcache%‘查询缓存情况

Qcache_hits:命中次数

Qcache_inserts:未命中后插入次数

二、MySQL解析器和预处理

Parser解析器

SQL命令传递到解析器的时候会被解析器验证和解析,主要功能为:

  1. 解析器将SQL语句分解成数据结构,并将这个结构传递到后续步骤,以后SQL的传递和处理都是基于这个结构的
  2. 如果在分解成数据结构中遇到错误,那么就说明这个SQL语句是不合法的

预处理

三、MySQL查询优化器

查询优化器将语法树转换为执行计划,并找出最好的执行计划。

可以使用explain查看查询优化器的操作,编写SQL语句的方式决定查询优化器如何使用索引。

参考:http://blog.chinaunix.net/uid-570310-id-2734848.html

时间: 2024-10-16 14:23:39

SQL查询执行过程的相关文章

SequoiaDB的查询执行过程

SequoiaDB的查询执行过程 继续读了SDB的代码,重点还是内核的代码.从客户端–查询优化-查询执行的过程来描述一下查询的过程.希望可以搞清楚2个问题: SDB能做什么查询? 搞清楚SDB是怎么做查询的? 第一个问题的答案是: 理论上,SDB能做mongoDB能做的所有查询,SDB还支持SQL(我指的是SDB内建的支持,不是通过PG支持的查询) 实际上,我没有一个一个去测,SDB看起来mongoDB类的查询基本上完成了:SQL的支持还更像一个玩具.至于说我怎么得到这个结论的,请看下面的分析吧

mysql之sql语句执行过程

1.SQL语句执行过程  1.客户端发送一条sql查询语句给服务器;     2.服务器通过权限检查之后,首先会检查查询缓存,如果命中了缓存,则立即返回 存储在缓存中的结果,否则进入下一步;     3.服务器端进行sql解析,预处理,再由查询优化器根据该sql所涉及的数据表的统计信息进行计算,生成对应的执行计划;     4.mySQL根据查询优化器生成的执行计划,调用存储引擎的API来执行查询;      5.将查询结果返回给客户端;    2.SQL语句执行过程的注意事项 1.在执行查询时

Oracle是如何工作的?实例是如何响应用户请求?一条SQL的执行过程~

Oracle 是如何工作的? Select id,name from t order by id ; – SQL 解析(查看语法是否错误,如果没有错误,分析语意,执行此语句的权限) – 执行计划(ORACLE如何访问数据,按照执行计划取数据) – 执行SQL • 从磁盘中读取数据(如果数据在内存中没有,就去磁盘读取) • 数据处理(数据读到内存后,就进行处理.排序,组合等处理) • 返回结果(把结果返回给用户) Insert into t values(1,‘tigerfish’); – SQL

oracle学习笔记 SQL语句执行过程剖析讲课

oracle学习笔记 SQL语句执行过程剖析讲课 这节课通过讲述一条SQL语句进入数据库 和其在数据库中的整个的执行过程 把数据库里面的体系结构串一下. 让大家再进一步了解oracle数据库里面的各个进程.存储结构以及内存结构的关联关系. 首先来讲整个体系中有客户端.实例和数据库 数据库里有三类文件 控制文件ctl.数据文件dbf.日志文件log 实例中SGA有六大池子 第一大内存区shared pool即共享池 第二大内存区buffer cache 第三块是redo log 我们主要讲上面的三

sql 查询执行的详细时间profile

1.查看profile的设置 SHOW VARIABLES LIKE '%profil%' 结果如下:profiling OFF 为关闭状态 2.开启profile SET profiling=1 结果: 3.执行需要执行的sql explain   select*........ 4.查询执行的sql SHOW PROFILES 结果: 5.查看需要的sql执行详细信息 SHOW PROFILE FOR QUERY 308 结果: SHOW profile cpu,MEMORY FOR QUE

SQL语句执行过程详解

一.SQL语句执行原理: 第一步:客户端把语句发给服务器端执行 当我们在客户端执行select语句时, 客户端会把这条SQL语句发送给服务器端,让服务器端的进程来处理这语句.也就是说,Oracle客户端是不会做任何的操作,它的主要任务就是把客户端产生的一些SQL语句发送给服务器端.虽然在客户端也有一个数据库进程,但是,这个进程的作用跟服务器上的进程作用不同.服务器上的数据库进程才会对SQL语句进行相关的处理.不过,有个问题需要说明,就是客户端的进程跟服务器的进程是一 一对应的.也就是说,在客户端

[转] Oracle sql 语句执行过程图文分析

[原文链接]  http://nvd11.blog.163.com/blog/static/200018312201301310585758/ [原文视频]  http://www.jiagulun.com/thread-2674-1-1.html 1. 数据库文件Oracle 数据库文件大概可分为3种,分别是:控制文件(control files): 存放数据库本身物理结构信息数据文件(data files): 存放数据库数据啦~日志文件(log files):  包括重做日志文件和归档日志文

mysql-一条sql的执行过程

1,登陆账号,链接上服务器. 2,取账号权限 3,(分析器)分析sql,是否符合语法.表名,是否存在,涉及表字段是否正确等等 4,(优化器)优化sql,是否需要使用索引.多个索引存在的情况下,哪个索引最合适.join 链接查询的话,先从哪个表开始比对等等 5,(执行器)查看是否有搜索涉及表的权限.执行sql.全表,或者索引树,一条一条比对下去 注意:账号权限在登陆时已经获取到了.登陆成功之后修改账号的密码不会影响已经建立链接的操作. 登陆账号之后建立了一个链接,链接长时间不使用的话,链接失效(w

跟踪oracle中sql语句执行过程及相关知识拓展

<pre name="code" class="sql">select * from v$sqlarea; select * from v$sqlarea where first_load_time>'2010-11-27/09:30:00'; 这个方法查询结果每条记录显示一条查询语句,且只能查询sql_text小于1000字符的,多余的会被截断. 改进一下: select * from v$sqlarea where first_load_tim