1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
| #一条SQL语句的执行过程 1>提供连接协议:TCP/IP 、SOCKET 2>提供验证:用户、密码,IP,SOCKET 3>提供专用连接线程:接收用户SQL,返回结果 通过以下语句可以查看到连接线程基本情况 mysql> show processlist;
#SQL层 1>接收上层传送的SQL语句 2>语法验证模块:验证语句语法,是否满足SQL_MODE 3>语义检查:判断SQL语句的类型 DDL :数据定义语言 DCL :数据控制语言 DML :数据操作语言 DQL: 数据查询语言 ... 4>权限检查:用户对库表有没有权限 5>解析器:对语句执行前,进行预处理,生成解析树(执行计划),说白了就是生成多种执行方案. 6>优化器:根据解析器得出的多种执行计划,进行判断,选择最优的执行计划 代价模型:资源(CPU IO MEM)的耗损评估性能好坏 7>执行器:根据最优执行计划,执行SQL语句,产生执行结果 执行结果:在磁盘的xxxx位置上 8>提供查询缓存(默认是没开启的),会使用redis tair替代查询缓存功能 9>提供日志记录(日志管理章节):binlog,默认是没开启的。
#存储引擎层 1>负责根据SQL层执行的结果,从磁盘上拿数据。 2>将16进制的磁盘数据,交由SQL结构化化成表,连接层的专用线程返回给用户
|