视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
大表更改默认值使用altertable不重建表,直接修改.frm_MySQL
2020-11-09 18:31:36 责编:小采
文档


bitsCN.com

大表更改默认值使用alter table不重建表,直接修改.frm

在mysql中执行很大部分的修改动作,都需要重建一个表,然后把数据放进去,最后删除旧的表!有时候要是有索引的列上进行大批且频繁的表的时候会导致系统的性能严重下降,这里可以在修改SQL上做部分调整,减轻相关的构建结构带来的系统压力问题! www.bitsCN.com

例如 在修改一个表的默认值为8的时候,常规做法为:

(1):alter table modes modify column dept tinyint(3) not null default 8;

这里通过一些show status分析出,每次都要做大量的句柄的读取和插入操作,类似于从新构建了一张新表的样式,这样在一些大表,上千万的数据量会出现瓶颈问题!

这里我们需要灵活知道mysql的相关默认值实际是放在相关的表结构.frm文件中;我们可以不经过数据层,可以直接调整!上述的modify column会导致相关的表进行拷贝操作,不利于系统的正常稳定运行,可以使用下面方式;

(2):alter table modes alter column dept set default 8;

这里只是更改了相关的frm文件,没有改动表,因此速度很快的即可完成;

总结:在此我们可以注意到相关的alter table后面跟不同形式的命令,可以对数据产生了不同程度的影响,这里还有一个change column操作也是不一样的!

bitsCN.com

下载本文
显示全文
专题