MySQL5.7 加强了在线DDL(varchar字符集)

  • 时间:
  • 浏览:3
  • 来源:uu快3大小_uu快3网站_开奖历史

本文转自hcymysql51CTO博客,原文链接: http://blog.51cto.com/hcymysql/1568929,如需转载请自行联系原作者

在MySQL5.6引入了在线DDL,上加字段和辅助索引不锁表,但修改字段属性是锁表的。请见:http://hcymysql.blog.51cto.com/522360 1/1370546

60 万行的表,现在要把pad varchar(65)修改为pad varchar(60 ),可不还可以 看多,不不拷贝数据不锁表。

参考:

但由于是大于并等于varchar(256)由于把varchar(60 )减少到varchar(40),仍旧是时要拷贝数据且锁表,见下图:

BTW:

MySQL5.7还支持更改索引名,不过实用性不高,谁没事闲得改索引的名字?例:

(注:ALGORITHM指定了创建或删除索引的算法,COPY表示按照MySQL 5.1版本想要的依据,即创建临时表。INPLACE表示创建索引或删除索引操作不时要创建临时表。DEFAULT表示根据参数old_alter_table来判断是通过INPLACE还是COPY的算法,改参数默认为OFF,表示采用INPLACE的依据。)

如今在MySQL5.7,加强了修改varchar字段属性不锁表,例: