mysql之DDL

举报
黄啊码 发表于 2022/06/29 00:41:34 2022/06/29
【摘要】 一 简介:今天来DDL的变革 二 DDL演化方式:   1 copy table : 1 创建临时表2 copy数据到临时表 3 rename进行交换 缺点 1 阻塞事务 2占用磁盘空间   2 inplace : 1 在线更改表,不会拷贝临时表 缺点 1 阻塞事务   3 online_ddl :1 在线...

一 简介:今天来DDL的变革
二 DDL演化方式:
  1 copy table : 1 创建临时表2 copy数据到临时表 3 rename进行交换 缺点 1 阻塞事务 2占用磁盘空间
  2 inplace : 1 在线更改表,不会拷贝临时表 缺点 1 阻塞事务
  3 online_ddl :1 在线更改表,不会拷贝临时表 优点 1 不会阻塞事务
  因此MySQL最新版本中,InnoDB支持了所谓的Online方式DDL。与以上两种方式相比,online方式支持DDL时不仅可以读,还可以写,对于dba来说,这是一个非常棒的改进。
三 DDL 耗时排行
  1 针对 索引的DDL操作
    特点:耗时少,表的数据量大,也不会很长时间,(随着表数据量的增多,加索引的速度会变得越来越慢)
    在线变更: 支持->inplace方式->不会阻塞事务
    特殊情况:针对全文索引要特殊对待
 2 针对 列的DDL操作(不包含主键) 
    特点:耗时长,表的数据量大,时间会非常长
    在线变更: 支持
    add column->inplace 方式->不会阻塞事务, 时间可能很长

   delete column -> inplace 方式->不会阻塞事务, 时间可能很长
    change->copy 方式->会阻塞事务 , 时间可能很长
    设置 修改 column默认值->inplace 方式 ->不会阻塞事务,时间很快,直接修改frm文件
    设置 colunm not null/null->inplace 方式->不会阻塞事务,时间可能很长

    设置clounm current on update -> inplace 方式->不会阻塞事务,时间很短
    drop column ->inplace 方式 ->不会阻塞事务,时间可能很长

 

  3 针对主键的DDL操作
   特点:耗时长,只针对特定场景进行操作
   在线变更: 支持
   add primary->inplace 方式->不会阻塞事务,时间可能很长
   drop primary->copy 方式->会阻塞事务,时间可能很长
   删除并添加主键->inplace 方式->不会阻塞事务,时间可能很长,而且必须在同一alter语句上
 4 其他特殊操作
  1 更改表的字符集 方式->copy,会阻塞事务,时间可能很长
   2 整理表空间 方式->inplace,不会阻塞事务(alter table engine=innodb)
四 总结
1 对于针对主键和列的更改操作建议采用pt-osc操作

2 针对myisam的表操作

 1 都需要copy to tmp table 这点要尤为注意,上面分析的都是innodb的操作

 2 由于myisam也支持触发器,所以可以用pt-osc进行操

文章来源: markwcm.blog.csdn.net,作者:黄啊码,版权归原作者所有,如需转载,请联系作者。

原文链接:markwcm.blog.csdn.net/article/details/105414720

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。