MySQL中的SQL是如何执行的

MySQL是典型的C/S架构,也就是Client/Server架构,服务器端程序使用的mysqld.整体的MySQL流程如下图所示:

MySQL是有三层组成:

  1. 连接层: 负责客户端与服务器端建立连接,客户端发送SQL至服务端;
  2. SQL层: 对SQL语句进行查询处理;
  3. 存储引擎层: 与数据库文件打交道,负责数据的存储和读取.

其中,SQL层与数据库文件的存储方式无关,我们来看下SQL层的架构:

  1. 查询缓存: Server如果在查询缓存中发现了这条SQL语句,就会直接将结果返回给客户端;如果没有,就进入到解析器阶段.格外注意的是,因为查询缓存往往效率不高,所以在MySQL8.0之后就抛弃了缓存.
  2. 解析器: 在解析器中对SQL语句进行语法分析和语义分析.
  3. 优化器: 在优化器中会确定SQL语句的执行路径,比如说是根据全表检索,还是根据索引来检索等.
  4. 执行器: 在执行前需要判断用户是否具备权限,如果具备权限就执行SQL查询并返回结果.在MySQL8.0以下的版本,如果设置了查询缓存,这时会将查询结果进行缓存.

SQL语句在MySQL中的流程是: SQL语句 -> 缓存查询 -> 解析器 -> 优化器 -> 执行器.

说说存储引擎,MySQL的存储引擎采用了插件的方式,每个存储引擎都面向一种特定的数据库应用环境.同事MySQL还允许开发人员设置自己的存储引擎.下面列举常见的存储引擎:

  1. InnoDB存储引擎: 是MySQL5.5.8版本之后默认的存储引擎,最大的特点是支持事务、行级锁定、外键约束等.
  2. MyISAM存储引擎: 在MySQL5.5.8版本之前是默认的存储引擎,不支持事务,也不支持外键,最大的特点是速度快,占用资源少.
  3. Memory存储引擎: 使用系统内存作为存储介质,以便得到更快的响应速度.不过如果mysqld进程崩溃,则会导致所有的数据丢失,因此只有当数据是临时数据的情况下才会使用Memory引擎.
  4. NDB存储引擎: 也叫做NDB Cluster存储引擎,主要用于MySQL cluster分布式集群环境,类似于Oracle的RAC集群.
  5. Archive存储引擎: 有很好的压缩机制,用于文件归档,在请求写入时会进行压缩,所以经常用来做仓库.

注意,数据库的设计在于表的设计,所以MySQL中每个表的设计都可以采用不同的存储引擎,可以根据实际情况的数据处理需要来选择存储引擎,这个是MySQL强大的地方.

数据库管理系统也是一种软件

完成的MySQL结构图如下:

profiling的使用,开启profiling可以让MySQL收集在SQL执行时所使用的资源情况,命令如下

select @@profiliong;

返回结果如果是0表示关闭,如果是1表示打开.可以使用 set profiling = 1;将profiling打开.

接下来可以执行sql语句,然后使用 show profiles来查询当前会话产生的所有peofiles.

前面会有query_id,可以使用show profile;获取上次查询执行的时间,或者使用show profile for query id;查询指定的query id执行的时间.

当然还有oracle的执行过程,这个暂时不研究.

Mysql中的sql是如何执行的 --- 极客时间学习笔记的更多相关文章

  1. SQL的概念与发展 - 极客时间学习笔记

    了解SQL SQL的两个重要标准是SQL92和SQL99. SQL语言的划分 DDL,也叫Data Definition Language,也就是数据定义语言,用来定义数据库对象,包括数据库.数据表和 ...

  2. MYSQL实战-------丁奇(极客时间)学习笔记

    1.基础架构:一条sql查询语句是如何执行的? mysql> select * from T where ID=10: 2.基础架构:一条sql更新语句是如何执行的? mysql> upd ...

  3. MySQL的过滤(极客时间学习笔记)

    数据过滤 SQL的数据过滤, 可以减少不必要的数据行, 从而可以达到提升查询效率的效果. 比较运算符 在SQL中, 使用WHERE子句对条件进行筛选, 筛选的时候比较运算符是很重要. 上面的比较运算符 ...

  4. MySQL的select(极客时间学习笔记)

    查询语句 首先, 准备数据, 地址是: https://github.com/cystanford/sql_heros_data, 除了id以外, 24个字段的含义如下: 查询 查询分为单列查询, 多 ...

  5. Mysql实战45讲 06讲全局锁和表锁:给表加个字段怎么有这么多阻碍 极客时间 读书笔记

    Mysql实战45讲 极客时间 读书笔记 Mysql实战45讲 极客时间 读书笔记 笔记体会: 根据加锁范围:MySQL里面的锁可以分为:全局锁.表级锁.行级锁 一.全局锁:对整个数据库实例加锁.My ...

  6. Mysql实战45讲 05讲深入浅出索引(下)极客时间 读书笔记

    极客时间 Mysql实战45讲 04讲深入浅出索引(下)极客时间 笔记体会: 回表:回到主键索引树搜索的过程,称为回表覆盖索引:某索引已经覆盖了查询需求,称为覆盖索引,例如:select ID fro ...

  7. mysql实战45讲读书笔记(二) 一条SQL更新语句是如何执行的 极客时间

    前面我们系统了解了一个查询语句的执行流程,并介绍了执行过程中涉及的处理模块.相信你还记得,一条查询语句的执行过程一般是经过连接器.分析器.优化器.执行器等功能模块,最后到达存储引擎. 那么,一条更新语 ...

  8. mysql实战45讲 (三) 事务隔离:为什么你改了我还看不见 极客时间读书笔记

    提到事务,你肯定不陌生,和数据库打交道的时候,我们总是会用到事务.最经典的例子就是转账,你要给朋友小王转100块钱,而此时你的银行卡只有100块钱. 转账过程具体到程序里会有一系列的操作,比如查询余额 ...

  9. [转]Mysql中的SQL优化与执行计划

    From : http://religiose.iteye.com/blog/1685537 一,如何判断SQL的执行效率? 通过explain 关键字分析效率低的SQL执行计划. 比如: expla ...

随机推荐

  1. securecrt如何保存操作日志

  2. RC4 对称加密

    public class RC4 { byte[] s = new byte[256]; byte[] key; byte keylen;// 4 ~ 16 int pi = 0; int pj = ...

  3. matplotlib画3D图修改X,Y,Z,colorbar的刻度值

    修改X,Y,Z轴的刻度值 from matplotlib.ticker import MultipleLocator,FuncFormatter from mpl_toolkits.mplot3d i ...

  4. 【西北师大-2108Java】第三次作业成绩汇总

    [西北师大-2108Java]第三次作业成绩汇总 熟悉PTA平台线上测试环境: 理解用户自定义类的定义: 掌握对象的声明: 学会使用构造函数初始化对象: 使用类属性与方法的使用掌握使用: 掌握pack ...

  5. python线程类的start()和run()

    start()方法: 开始线程活动. 对每一个线程对象来说它只能被调用一次,它安排对象在一个另外的单独线程中调用run()方法,而非当前所处的线程,当该方法在同一个线程对象中被调用超过一次时,会引入R ...

  6. vue中keepAlive的使用

    在开发中经常有从列表跳到详情页,然后返回详情页的时候需要缓存列表页的状态(比如滚动位置信息),这个时候就需要保存状态,要缓存状态:vue里提供了keep-alive组件用来缓存状态.可以用以下几种方案 ...

  7. leetcode494. 目标和

    给定一个非负整数数组,a1, a2, ..., an, 和一个目标数,S.现在你有两个符号 + 和 -.对于数组中的任意一个整数,你都可以从 + 或 -中选择一个符号添加在前面. 返回可以使最终数组和 ...

  8. A1010 Radix (25 分)

    一.技术总结 首先得写一个进制转换函数convert(),函数输入参数是字符串str和需要转化的进制(使用long long数据类型).函数内部知识,使用函数迭代器,即auto it = n.rbeg ...

  9. [算法模版]子序列DP

    [算法模版]子序列DP 如何求本质不同子序列个数? 朴素DP 复杂度为\(O(nq)\).其中\(q\)为字符集大小. \(dp[i]\)代表以第\(i\)个数结尾的本质不同子序列个数.注意,这里对于 ...

  10. vue+elementui+netcore混合开发

    1.VueController.cs using Bogus; using System; using System.Collections.Generic; using System.Linq; u ...