百木园-与人分享,
就是让自己快乐。

mysql 大表加索引或者往大表里面加字段

   通常我们往大表里面添加索引或者添加新字段,不能直接执行,执行时间很长,造成锁表操作,必须借助于pt或者gh-ost等数据库管理工具添加。

    例子如下:

        pt-online-schema-change -h服务器地址 -u\'用户名\' -p\'密码\' --alter=\"加字段|索引语句 \" --execute D=数据库名称,t=表名

   实现的逻辑是基于原表创建一个临时表,然后对临时表(空表)进行添加索引或者添加字段操作,然后将表a的数据迁移到临时表b(为了保持这段时间新的操作不会影响一致性,使用了redo_log),然后两表换名,类似于重建表(或者收缩表)的语句:alter table T engine = innodb;----------能够去除老表空洞,页分裂问题,达到收缩表空间的目的

来源:https://www.cnblogs.com/zc2276853313/p/14663860.html
图文来源于网络,如有侵权请联系删除。

未经允许不得转载:百木园 » mysql 大表加索引或者往大表里面加字段

相关推荐

  • 暂无文章