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

mysql在线DDL(与oracle的区别)

时间:2016-04-08 20:14:56      阅读:387      评论:0      收藏:0      [点我收藏+]

标签:mysql ddl

对mysql有所研究的都知道,当mysql某个业务表上有未提交的活动事务的时候,你去执行在线DDL,这相当危险,直接会被卡住,show processlist里面会显示这个DDL遇到了MDL锁等待,即“waiting for table metadata lock",此时如果你去喝咖啡去了。。。杯具就发生了,因为此时这个业务表连select都会被阻塞。


mysql在5.6官方文档里面说自己可以支持大部分在线DDL了,包括常见的加字段、加索引、改字段等等。但是要注意:这里所谓的支持在线DDL,指的是针对死表(执行DDL前表上没有未提交的事务)的情况,即在mysql5.6里对死表执行DDL的时候,不会出现mysql5.5的”copy to tmp table"的情况,只是提示“altering table",在DDL执行期间不会像mysql5.5一样阻塞这个表上的DML。


但是生产系统的繁忙业务表,肯定是活表(表上每时每刻都有未提交的事务),所以在上面搞在线DDL则是另外的话题了,这里不详细解释。


但是有一点,mysql没有oracle做得好,mysql一些危险的sql,在执行的时候,会直接卡住,没有任何提示,很不友好,如下:

技术分享


oracle,在一个有活动事务的表上执行DDL的时候,oracle会报

“ORA-00054: resourcebusy and acquire with NOWAIT specified”,这种提示就非常友好了。


本文出自 “记忆碎片” 博客,谢绝转载!

mysql在线DDL(与oracle的区别)

标签:mysql ddl

原文地址:http://weikle.blog.51cto.com/3324327/1761836

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