MySQL如何优雅的执行DDL
💡
原文中文,约6600字,阅读约需16分钟。
📝
内容提要
本文介绍了MySQL DDL表结构变更的两种方式:pt-osc和Online DDL,分析了它们的优缺点和影响。同时讨论了加锁情况和各种DDL操作的差异。建议根据具体情况选择合适的方式进行表结构变更。
🎯
关键要点
- 本文介绍了MySQL DDL表结构变更的两种方式:pt-osc和Online DDL。
- pt-osc和Online DDL各自有优缺点,选择时需根据具体情况。
- MySQL 5.7版本的表结构变更机制分析。
- Online DDL通过Innodb引擎执行表变更,可能会锁表并引发复制延迟。
- pt-osc通过创建新表和触发器进行数据同步,避免了复制延迟。
- 加锁情况在MySQL 5.7中相对较好,通常只在执行前后加表元数据锁。
- 不同DDL操作在选择Online DDL和pt-osc时的差异分析。
- 创建普通二级索引时,Online DDL执行时间较短,但需考虑复制延迟。
- 删除索引和索引重命名时,Online DDL速度快,几乎瞬间完成。
- 涉及主键和唯一索引的操作,建议使用Online DDL。
- 添加、删除列等操作在Online DDL和pt-osc中效果相似,但需注意锁表情况。
- 修改列名、设置/删除默认值等操作,Online DDL速度极快,直接选用。
- 对于外键操作,建议避免使用以减少风险。
- 修改表名、表碎片整理等操作,Online DDL瞬间完成,pt-osc为首选。
- 表分区操作中,普通表转分区表时建议使用pt-osc。
- 总结:DDL操作较多,选择合适的方式需根据具体情况。
🏷️
标签
➡️