赞
踩
原生MySQL只支持不跨越256字节的在线扩展(online),对于跨越256字节的扩展只支持复制方式(copy),扩展时需要锁表且禁止对数据表进行写操作。
varchar字段的存储由两部分构成,即长度前缀(length prefix)和数据
占位长度byte变化,或者新增字段,会导致数据重写,从而导致主从延迟
历史遗留问题,早期版本的varchar的长度用一个字节表示,255则为一个byte长度的临界值(255字节+1字节的长度位),为了向下兼容,就保留在了255
用于不停服发版,如果某一个字段由于长度限制需要扩容,就可以从这一点考虑是否会产生祖冲同步延迟的情况
- alter table about modify name_en varchar(63) default null,algorithm=inplace; -- 255-63 无法修改
-
- alter table about modify name_en varchar(256) default null,algorithm=inplace; -- 255-256 可修改
-
- alter table about modify name_en varchar(63) default null,algorithm=copy; -- 256-63 可修改
-
- alter table about modify name_en varchar(64) default null,algorithm=inplace; -- 63-64 不可修改
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。