online DDL特性可以使很多ALTER TABLE操作避免表的复制,以及在DDL执行过程中对DML操作的阻塞。
它具有下面的优点:
在繁忙的生产系统中,当你修改索引或字段定义的时候,你可能会让一张表再几分钟内不可用,这个特性提高了数据库的响应速度和高可用性。
这个特性让你在DDL操作的时候,通过选择是否阻塞对整张表的访问(LOCK=EXCLUSIVE语句,既不允许查询,也不允许DML操作),或允许查询但不允许DML操作(LOCK=SHARED语句),或同时允许查询和DML操作(LOCK=NONE语句),来平衡性能和并发。当你忽略LOCK语句或者指定LOCK=DEFAULT时,MySQL会根据操作的类型允许尽可能多的并发。
通过执行in-place操作而不是创建整张表的拷贝和相关索引的重建,来避免磁盘I/O压力的大量增加。
--使用INPLACE方式增加主键
ALTER TABLE add_pk_via_inplace ADD PRIMARY KEY (c1,c2,c3), ALGORITHM=INPLACE;
--以重建的方式删除索引,是否磁盘空间
drop index i_dtyp_big on big_table, algorithm=copy;
上一篇:怎么解决启动mysql时报错The server quit without updating PID file问题
下一篇:怎么解决数据库ERROR 1524 (HY000): Plugin is not loaded问题
mysql









