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

MySQL5.6 CREATE TABLE源码分析

时间:2018-05-13 21:36:52      阅读:252      评论:0      收藏:0      [点我收藏+]

标签:MySQL create table

技术分享图片
MySQL5.6之前的版本DDL是非原子的。也就是说对于复合的DDL,比如DROP TABLE t1, t2;执行过程中如果遇到server crash,有可能出现表t1被DROP掉了,但是t2没有被DROP掉的情况。即便是一条DDL,比如CREATE TABLE t1(a int);也可能在server crash的情况下导致建表不完整,有可能在建表失败的情况下遗留.frm或者.ibd文件。

从原理流程图中可以看出,create table先创建.frm文件,再调用ha_create_table创建ibd文件,如果创建成功则退出,否则将之前创建的frm文件删除。但是这里就有问题了,如果创建完frm文件后,server挂了,那么frm文件是创建成功了,但是ibd文件没有创建。这就是DDL非原子性导致的后果。

MySQL5.6 CREATE TABLE源码分析

标签:MySQL create table

原文地址:http://blog.51cto.com/yanzongshuai/2115772

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