MySQL DBA应该都知道,数据库操做里面,DDL操做(好比CREATE,DROP,ALTER等)代价是很是高的,特别是在单表上千万的状况下,加个索引或改个列类型,就有可能堵塞整个表的读写。mysql
从MySQL 5.6开始,你们期待的Online DDL出现了,能够实现修改表结构的同时,依然容许DML操做(select,insert,update,delete)。但改变字段类型,好比从CHAR变为VARCHAR;修改字段类型,好比增长VARCHAR大小,这些在MySQL 5.7以前仍是会锁表的。从MySQL 5.7开始就支持了对于tinyint、int、smallint、bigint等数值类型的数据类型,自身位大小的增大或减少是支持ONLINE的(注意:不支持从tinyint变动为int)。还支持了VARCHAR类型的在线增大,但也有些限制。sql
支持了对于tinyint、int、smallint、bigint等数值类型的数据类型,自身位大小的增大或减少是支持ONLINE的(注意:不支持从tinyint变动为int),以下:数据库
mysql> alter table t1 change id id bigint(10),ALGORITHM=INPLACE,LOCK=NONE;ui
Query OK, 0 rows affected (0.01 sec)this
Records: 0 Duplicates: 0 Warnings: 0索引
mysql> alter table t1 change id id bigint(30),ALGORITHM=INPLACE,LOCK=NONE;table
Query OK, 0 rows affected (0.01 sec)test
Records: 0 Duplicates: 0 Warnings: 0require
另外,若是是更改字段属性(类型不变)根据类型不一样支持的Online DDL也是有限的,如把容许为NULL变动为不容许为NULL就不支持。date
mysql> alter table sbtest change column dd dd varchar(100) not null,ALGORITHM=INPLACE,LOCK=NONE;
ERROR 1846 (0A000): ALGORITHM=INPLACE is not supported. Reason: cannot silently convert NULL values, as required in this SQL_MODE. Try ALGORITHM=COPY;
可是在线支持变动comment属性。
mysql> alter table info change dd dd varchar(100) null comment "test",ALGORITHM=INPLACE,LOCK=NONE;
须要注意的是,在MySQL 5.6以前使用ALTER TABLE … ALGORITHM=INPLACE的表不支持包含时间列(DATE,DATETIME,TIMESTAMP),否则会报错。
MySQL 5.7版本支持重命名索引和修改varchar的大小(增大不能减少),且无需table-copy(秒级增长varchar大小)。这两项操做在以前的版本中,都须要重建索引或表,适用于各引擎。