MySQL底层理解(一‘)

MySQL底层理解

MySQL基础架构

1、Server层和存储引擎层各是什么作用,MySQL的框架有几个组件, 各是什么作用?

整体分为server层和存储引擎层两个部分

server层包括:
  1. 连接器:客户端与之连接,获取权限、维持和管理连接。连接命令为mysql -h$ip -P$port -u$user -p,输完命令后会要求你输出密码,密码也可以直接跟在-p后面,但是不安全。一个用户连接成功后,管理员对该用户更改权限,生效在下次连接时。

    show processlist查看空闲连接,如果Command列显示为sleep,就表示空闲,空闲默认时8小时,超时自动断开,连接过程复杂,建议使用长连接,连接比较占用内存,需要定时断开,5.7之后可以使用mysql_reset_connection设置

  2. 分析器:词法分析,语法分析,验证语法的合规性,把sql转化成MySQL内部识别的语句,表明转换成对应的id

  3. 优化器:执行计划生成,索引选择,判断SQL内部的执行顺序,作用:在表里面有多个索引的时候,决定使用哪个索引;或者在一个语句有多表关联(jion)的时候,决定各个表的连接顺序。

  4. 执行器:操作引擎,返回结果,验证操作库是否有权限,调用存储引擎接口查询数据

  5. 查询缓存:查询命中,直接返回结果,效果很高,但是查询缓存弊大于利,它的失效非常频繁,只要有对一个表的更新,这个表上的所有查询缓存都会被清空。8.0版本没有此功能

涵盖MySQL的大多数核心服务功能,以及所有的内置函数(如日期,时间,数学,加密函数等),所有跨存储引擎的功能都在这一层实现,比如存储过程触发器视图

存储引擎:负责数据的存储和提取,其架构是插拔式的,支持InnoDB,MySAM,Memory等多个存储引擎。最常用InnoDB,从5.5.5后,MySQL默认InnoDB引擎。

2、you have an error in your SQL syntax 这个保存是在词法分析里还是在语法分析里报错?

出现在语法分析:该分析器会根据语法规则,判断输入的SQL语句是否满足MySQL语法,如果语法不对,就会报错题干的提示信息。

3、对于表的操作权限验证在哪里进行?

答:执行器;执行器在开始执行的时候,要先判断一下对表有没有查询的权限,如果没有就返回错误。如果查询命中缓存会在查询缓存返回结果的时候,做权限验证,查询也会在优化器之前调用precheck验证权限

4、执行器的执行查询语句的流程是什么样的?

 select * from T where ID=10;

以该例说明:(例子中的表T,ID字段没有索引)

  1. 调用InnoDB引擎接口取这个表T的第一行,判断ID的值是不是10,如果不是则跳过,如果是则将这行存在结果集中;
  2. 调用引擎接口取“下一行”,重复相同的判断逻辑,直捣取到这个表的最后一行
  3. 执行器将上述遍历过程中所有满足条件的行组成的记录集作为结果集返回给客户端

5、慢查询日志中的rows_examined代表什么?

该字段表示查询语句执行过程中扫描了多少行,它的值就是在执行器每次调用引擎获取数据行的时候累加的;在有些场景下,执行器调用一次,在引擎内部扫描了多行,因此引擎扫描行数跟rows_examined并不完全相同

你可能感兴趣的:(mysql)