01|基础架构:一条查询语句的执行流程

1. 基本架构

  大体来说,MySQL可以分为Server层和存储引擎两部分。

  Server层包括链接器,分析器,优化器,执行器等,涵盖大多数核心服务功能,一般跨存储引擎的功能都在这一层实现,比如存储过程,触发器,视图等。

  存储引擎负责数据的存储和提取。其架构模式是插件式,支持InnoDB,MyISAM,Memory等存储引擎,MySQL5.5.5版本后默认引擎为InnoDB。

1.1 连接器

  负责和客户端建立连接,获取权限,维持和管理连接。

  常用命令:mysql    -h127.0.0.1    -P3306    -uroot  -p123456

  连接认证通过后,连接器在权限表中查询你拥有的权限,之后这个连接的权限逻辑判断都依赖此时读到的权限。这意味着一个连接一旦建立后,之后就算修改这个用户的权限,也不会影响已经存在连接的权限。

  可以通过 show processlist查看当前所有连接的状态;

  

  连接完成后如果没有其他操作,将处于空闲状态,空闲状态的连接存在时间有一定限制。由参数wait_timeout控制,默认8小时。

  关于连接的优化:

  1. 定期断开连接。使用一段时间或者执行过一个占用内存的大查询之后主动断开连接;

  2. 在5.7版本后,可通过执行 mysql_reset_connection 重新初始化连接;

1.2 查询缓存

  执行查询语句时,先在缓存中查询,缓存命中失败后再去数据库查询;

  一般以查询语句为 key, 查询的结果集为 value ,以键值对的形式将查询结果缓存在内存中。

  优点:查询缓存命中率较高时,可以大幅提高查询效率;

  缺点:一般情况下缓存失效的情况较多,一旦对某个表进行更新,这个表的所有查询缓存会被清空;

  8.0 版本已经不支持查询缓存功能。

1.3 分析器

  根据语法规则判断SQL语句是否满足SQL语法,判断表是否存在,列是否存在等等;

1.4 优化器

  根据索引或其他规则,优化SQL语句,可能更改SQL语句的执行顺序,但是不会影响查询结果;

1.5 执行器

  执行SQL语句之前,进行权限校验,然后进行操作;

原文地址:https://www.cnblogs.com/virgosnail/p/10322268.html

时间: 2024-08-30 11:31:53

01|基础架构:一条查询语句的执行流程的相关文章

MySQL实战01の一条查询语句怎么执行的

先看大致流程,MySQL 可以分为 Server 层和存储引擎层两部分 连接器 连接器负责跟客户端建立连接,获取权限,维持和管理连接.长连接的参数设置 wait_timeout.MySQL5.7+版本可以使用 mysql_reset_connection初始化连接资源 查询缓存 a) 之前执行过的select语句,会以key-value的形式保存在内存中.如果查询语句与key相同,直接返回结果value. b) 大多数情况下不建议使用查询缓存,对于很长时间才会更新的静态表(系统配置表等)才适合使

mysql(1)—— 详解一条sql语句的执行过程

SQL是一套标准,全称结构化查询语言,是用来完成和数据库之间的通信的编程语言,SQL语言是脚本语言,直接运行在数据库上.同时,SQL语句与数据在数据库上的存储方式无关,只是不同的数据库对于同一条SQL语句的底层实现不同罢了,但结果相同.这有点类似于java中接口的作用,一个接口可以有不同的实现类,不同的实现类对于接口中方法的实现方式可以不同,结果可以相同.这里SQL语言的作用就类似于java中的接口,数据库就类似于java中接口的实现类,SQL语句就类似于java接口中的方法.不同的是java中

详解一条sql语句的执行过程

SQL是一套标准,全称结构化查询语言,是用来完成和数据库之间的通信的编程语言,SQL语言是脚本语言,直接运行在数据库上.同时,SQL语句与数据在数据库上的存储方式无关,只是不同的数据库对于同一条SQL语句的底层实现不同罢了,但结果相同.这有点类似于java中接口的作用,一个接口可以有不同的实现类,不同的实现类对于接口中方法的实现方式可以不同,结果可以相同.这里SQL语言的作用就类似于java中的接口,数据库就类似于java中接口的实现类,SQL语句就类似于java接口中的方法.不同的是java中

一条sql语句具体执行过程

客户端发送一条查询语句给服务器 服务器先检查缓存,如果有就直接返回数据,否则进入下一个阶段. 服务器进行sql解析,预处理,再由优化器生成对应的执行计划 根据执行计划,调用API接口来执行查询 返回结果给客户端,并缓存 一条sql语句具体执行过程,布布扣,bubuko.com

浅谈SQL优化入门:1、SQL查询语句的执行顺序

1.SQL查询语句的执行顺序 (7) SELECT (8) DISTINCT <select_list> (1) FROM <left_table> (3) <join_type> JOIN <right_table> (2) ON <join_condition> (4) WHERE <where_condition> (5) GROUP BY <group_by_list> (6) HAVING <having_

Oracle中的一些查询语句及其执行顺序

查询条件: 1)LIKE:模糊查询,需要借助两个通配符,%:表示0到多个字符:_:标识单个字符. 2)IN(list):用来取出符合列表范围中的数据. 3)NOT IN(list): 取出不符合此列表中的数据记录. 4)BETWEEN-AND-:用来查询符合某个值域范围条件的数据,最常见的是使用在数字类型的数据范围上,但对字符类型和日期类型数据也同样适用.for example:    SELECT ename, sal FROM emp WHERE sal BETWEEN 1500 AND 3

基本sql语句--sql执行流程及调优

SQL分类 和大多数关系型数据库一样,mysql也具有以下几种类型的SQL语句: DML语句:主要用于新增,修改,删除和查询数据库的记录,关键字:insert,update,delete和select DCL语句:主要用于控制数据库对象(库,表,字段.用户等对象)的访问,关键字:grant,revoke DDL语句:主要用于定义和修改数据库对象的结构,常用关键字:create,drop,alter 注:DML(DELETE,UPDATE,SELECT)才 是我们关注的重点,而其中DELETE,U

01基础架构,一条SQL查询语句是如何执行的?

SQL 语句在 MySQL 的各个功能模块中的执行过程. 大体来说,MySQL 可以分为 Server 层和存储引擎层两部分. Server 层包括连接器.查询缓存.分析器.优化器.执行器等,涵盖 MySQL 的大多数核心服务功能,以及所有的内置函数(如日期.时间.数学和加密函数等),所有跨存储引擎的功能都在这一层实现,比如存储过程.触发器.视图等. 存储引擎层负责数据的存储和提取.其架构模式是插件式的,支持 InnoDB.MyISAM.Memory 等多个存储引擎.现在最常用的存储引擎是 In

程序架构探讨—001 查询语句中多段select语句的方案

有时候,我们需要做多条件查询,多个条件为"或"的关系,分类查询等,一般会用到多段select语句,然后用union或者union all进行连接,进而查出需要的结果.例如,select a.id as id,a.name as name,a.age as agefrom scama.table_name2 awhere 1=1 union all select b.sn as id,b.name as name,b.age as agefrom scama.table_name2 bw