这篇文章主要讲解了“MySQL 5.7 online DDL特性有什么优点”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL 5.7 online DDL特性有什么优点”吧!
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 5.7 online DDL特性有什么优点”的内容了,经过本文的学习后,相信大家对MySQL 5.7 online DDL特性有什么优点这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!