MySQL客户端通过协议将SQL语句发送给MySQL服务器。
服务器会先检查查询缓存中是否有执行过这条SQL,如果命中缓存,则将结果返回,否则进入下一个环节(查询缓存默认不开启)。
服务器端进行SQL解析,预处理,然后由查询优化器生成对应的执行计划。
服务器根据查询优化器给出的执行计划,调用API给存储引擎(InnoDB 引擎:mysql 5.1 后默认的数据库引擎,MyIASM 引擎:不提供事务的支持,也不支持行级锁和外键)执行查询。
将结果返回给客户端,如果开启查询缓存,则会备份一份到查询缓存中。
mysql 自带的日志模块式binlog(归档日志),所有的存储引擎都可以使用,我们常用的InnoDB引擎还自带了一个日志模块redo log,· InnoDB引擎把数据保存在内存中,同时记录redo log,此时redo log进入prepare状态,然后告诉执行器,执行完成了,随时可以提交。
执行器收到通知后记录binlog,然后调用引擎接口,提交redo log 为提交状态。更新完成。如果redo log 只是预提交但不是commit状态,这个时候就会去判断binlog是否完整,如果完整就提交 redo log, 不完整就回滚事务。