本文共 422 字,大约阅读时间需要 1 分钟。
1 连接层
(1) 提供连接协议 Socket TCP/IP (2) 验证用户名(root@localhost)密码合法性,进行匹配专门的授权表。(3) 派生一个专用连接线程(接收SQL,返回结果)
mysql> show processlist;
2 SQL层(优化方面至关重要的)
(1)验证SQL语法和SQL_MODE (2)验证语义 (3)验证权限 (4)解析器进行语句解析,生成执行计划(解析树) (5)优化器(各种算法,基于执行代价),根据算法,找到代价最低的执行计划。 代价:CPU IO MEM (6)执行器按照优化器选择执行计划,执行SQL语句,得出获取数据的方法。 (7)提供query cache(默认不开),一般不开,会用redis (8)记录操作日志(binlog),默认没开
3 存储引擎层
真正和磁盘打交道的一个层次 根据SQL层提供的取数据的方法,拿到数据,返回给SQL,结构化成表,再又连接层线程返回给用户。
转载地址:http://ceepb.baihongyu.com/