码迷,mamicode.com
首页 > 数据库 > 详细

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

时间:2014-10-28 18:07:27      阅读:245      评论:0      收藏:0      [点我收藏+]

标签:mysql5.7   在线ddl   

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


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

bubuko.com,布布扣


100万行的表,现在要把pad varchar(65)修改为pad varchar(80),可以看到,不用拷贝数据不锁表。

bubuko.com,布布扣

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


但如果是大于并等于varchar(256)或者把varchar(80)减少到varchar(40),仍旧是需要拷贝数据且锁表,见下图:

bubuko.com,布布扣

bubuko.com,布布扣


参考:

bubuko.com,布布扣


BTW:

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

bubuko.com,布布扣

bubuko.com,布布扣



本文出自 “贺春旸的技术专栏” 博客,请务必保留此出处http://hcymysql.blog.51cto.com/5223301/1568929

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

标签:mysql5.7   在线ddl   

原文地址:http://hcymysql.blog.51cto.com/5223301/1568929

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!