mysql在线ddl操作

本文介绍了MySQL从5.6版本开始支持的在线DDL操作,它提高了生产环境的可用性并实现了性能与并发性的平衡。通过指定LOCK和ALGORITHM子句,可以控制DDL执行期间的锁定级别和表操作方式。在线DDL减少了表拷贝带来的影响,某些ALTER语句允许并发DML操作。文中通过示例展示了不同DDL操作对表的影响,如重命名列、更改列类型和添加列。此外,还讨论了CREATE INDEX对UPDATE语句的影响,并提到了innodb_online_alter_log_max_size参数对大量DML操作时的影响。
摘要由CSDN通过智能技术生成

mysql5.6开始支持在线ddl,在线ddl能够提供下面的好处;

1提高生产环境的可用性2在ddl执行期间,获得性能和并发性的平衡,可以指定LOCK从句与algorithm从句,lock=exclusize会阻塞整个表的访问,lock=shared会允许查询但不允许dml,lock=none允许查询和dml操作,lock=default或是没有指定,mysql使用最低级别的锁,algorithm指定是拷贝表还是不拷贝表直接内部操作,3只对需要的地方做改变,不是创建一个新的临时表。

之前ddl操作的代价是很昂贵的,许多的alter table语句是创建一个新的,按需要的选项创建的空表,然后拷贝已经存在的行到新表中,在更新插入行的索引,在所有的行被拷贝之后,老的表被删除,拷贝的表被重命名成原来表的名。

在5.5和5.1优化了的create index和drop index避免了表拷贝的行为,这个特色叫快速索引创建,56.增强了,在改变的时候dml还能处理,叫在线ddl。

一些alter语句允许并发的dml,但是仍然需要拷贝表,这些操作的表拷贝要比之前版本的快

  • Adding, dropping, or reordering columns.

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值