欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 教育 > 幼教 > mysql DDL可重入讨论

mysql DDL可重入讨论

2025/2/26 0:20:38 来源:https://blog.csdn.net/tlxamulet/article/details/145380190  浏览:    关键词:mysql DDL可重入讨论

mysql的bug:当执行 MySQL online DDL 时,期间如有其他并发的 DML 对相同的表进行增量修改,比如 update、insert、insert into … on duplicate key、replace into 等,且增量修改的数据违背唯一约束,那么 DDL 最后都会执行失败,报错主键冲突。

这里的“增量修改的数据违背唯一约束”,从实践来看即使insert into on duplicate执行成功,依然有可能触发DDL报错,并非一定要DML执行失败。

参考:

https://blog.csdn.net/Tony_stark_L/article/details/127596879

解决方案:

  • 重试DDL
  • 使用第三方工具 pt-osc 或者 gh-ost 执行在线 DDL
  • 在 DDL 语句中指定 ALGORITHM=COPY,但该过程中只允许查询,不允许写入

方案2要引入额外的工具,方案3的话mysql内部要新建临时表,多占一倍空间,且改表结构时不能写入对业务影响也较大。

故选择方案1,建议确保DDL是可重入的,可以做工具完成DDL的可重入检查。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词