Mysql 笔记

mysql 执行步骤 show processlist;//显示所有进程 过程讲解: 总结 执行一条 SQL 查询语句,期间发生了什么? 连接器:建立连接,管理连接、校验用户身份; 查询缓存:查询语句如果命中查询缓存则直接返回,否则继续往下执行。MySQL 8.0 已删除该模块; 解析 SQL,通过解析器对 SQL 查询语句进行词法分析、语法分析,然后构建语法树,方便后续模块读取表名、字段、语句类型; 执行 SQL:执行 SQL 共有三个阶段: 预处理阶段:检查表或字段是否存在;将 select * 中的 * 符号扩展为表上的所有列。 优化阶段:基于查询成本的考虑, 选择查询成本最小的执行计划; 执行阶段:根据执行计划执行 SQL 查询语句,从存储引擎读取记录,返回给客户端; redo log 及 binlog redo: redo属于存储引擎层(如InnoDB),记录了数据的偏移,适当时间会更新到硬盘。环形结构。 redo log 是物理日志,记录的是“在某个数据页上做了什么修改” binlog: binlog 是 MySQL 的 Server 层实现的,所有引擎都可以使用。 binlog 是逻辑日志,记录的是这个语句的原始逻辑,比如“给 ID=2 这一行的 c 字段加 1 ” 更新时逻辑,两阶段提交。 先redo log(prepare阶段),再binlog,最后commit 隔离级别 在 MySQL 中,实际上每条记录在更新的时候都会同时记录一条回滚操作。记录上的最新值,通过回滚操作,都可以得到前一个状态的值。 尽量不要使用长事务 当没有比回滚日志更早的读视图(读视图在事务开启时创建)的时候,这个数据不会再有谁驱使它回滚了,这个回滚日志也就失去了用武之地,可以删除了 ...

2025年04月05日