`
丁林.tb
  • 浏览: 789224 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

[MySQL 版本差异] 丢失frm文件之后drop database的不同结果分析

阅读更多

背景
 今天在讨论frm丢失后drop database失败的问题。简单复现如下。假设test库中有两个表t1, t2,执行如下脚本:

bin/mysql -uroot –socket=run/mysql.sock   -e ”
drop database if exists test2;
create database test2;
use test2;
create table t1 like test.t1;
create table t2 like test.t2;

rm -f data/test2/t1.frm;

bin/mysql -uroot –socket=run/mysql.sock   -e ”
flush tables;
drop database test2;

在5.1下会报一个错误
ERROR 1010 (HY000) at line 3: Error dropping database (can’t rmdir ‘./test2′, errno: 39)
并且在test2目录下留下一个t1.ibd。

分析
 MySQL执行drop database test2 的正常流程是这样如下:
1) 遍历 test2目录下的frm文件,依次调用对应表的drop table操作
2) 删掉目录data/test2
出现上面的这个现象的原因,是因为我们事先删掉了t1.frm,导致test2/t1这个表没有删除。这样遗留test2/t1.ibd. 对一个非空目录调用rmdir,就会报错。

5.5版本
 在5.5版本,执行上诉相同的操作,会发现drop database 操作正常完成。
 流程如下:
1) 遍历 test2目录下的frm文件,依次调用对应表的drop table操作
2) 调用innobase_drop_database, 再此期间会删掉test/t1.ibd
3) 删掉空目录 data/test2
由于在第二个步骤删掉了ibd文件,后续删除目录就能正常返回。

相关代码
但实际上在5.1版本的InnoDB中,就有这个接口innobase_drop_database, 会将那些没有frm的ibd文件也删除。(实际上InnoDB本身有字典,不需要通过遍历frm的方式)。
 但实现上代码如下:
    if ((deleted= mysql_rm_known_files(thd, dirp, db, path, 0,
                                       &dropped_tables)) >= 0)
    {   
      ha_drop_database(path);
      ……
    }
在 mysql_rm_known_files 会尝试删除data/test2/ , 但此时目录非空。又由于返回值问题导致ha_drop_database(path)不执行。

而5.5是先调用ha_drop_database再删目录。

可以认为是5.1 server层的一个bug。

1
1
分享到:
评论

相关推荐

    mysql frm转sql

    MySqlFrm.exe是c#版本的frm转sql工具,需要.net 4.0与mysql环境,CMD命令行如下: mysqlfrm <username> <password> <port> 例如: mysqlfrm root pass 3306 c:\dbcopy 会将c:\dbcopy目录下所有的frm转换为...

    mysql之frm文件解析.txt

    资料是对mysql frm文件的解析,通过分析frm文件可以获取到数据库的表,字段名等信息。

    读取MySQL的*.frm文件(解压密码:zcgonvh)

    当数据库损坏时,可以使用该工具,读取data文件夹下的frm文件,并生成数据结构的sql文件。 解压密码:zcgonvh

    mysql误删除frm和ibd文件的恢复方法.txt

    Mysql数据库由于断电重启或者手动误删frm和ibd文件导致表创建不成功。亲测可以重新创建成功

    MySql .frm数据库文件导入的问题

    在网上搜索了半天,最简单的办法是在新的数据库中创建和原名字一样的数据库,然后把.frm 文件拷贝进去就OK了。 可是,有些时候这样不行,查询的时候会出现某某表不存在的问题,在确认.frm ,db.opt 文件完整的情况下...

    根据mysql的.frm文件恢复建表语句

    仅根据mysql的.frm文件恢复出表结构 1、使用到的工具 mysqlfrm 2、安装mysql-utilities-1.6.5-winx64.exe 和?vcredist_x64.exe 3、管理员权限打开cmd cd 进入 %mysql-utilities-HOME%/ 运行: mysqlfrm --server=...

    MySQl 通过.frm 和 .ibd文件恢复数据.pdf

    MySQl 通过.frm 和 .ibd文件恢复数据

    MySQL利用idb文件恢复frm.rar

    MySQL利用db文件恢复frm 下载之后查看HELP.md 有什么不懂的 可以私信我。 java写的代码。 不会java警慎下载。。。。 (好用记得给好评额。 )

    详解MySQL中InnoDB的存储文件

    在MYSQL中建立任何一张数据表,在其数据目录对应的数据库目录下都有对应表的.frm文件,.frm文件是用来保存每个数据表的元数据(meta)信息,包括表结构的定义等,.frm文件跟数据库存储引擎无关,也就是任何存储引擎的...

    mysql 从 frm 文件恢复 table 表结构的3种方法【推荐】

    主要介绍了mysql 从 frm 文件恢复 table 表结构的3种方法 ,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下

    数据库恢复,恢复表结构读取frm文件

    mysql的灾后重建,前提是frm文件还存在,mysql的表结构文件是保存在frm文件中的,数据文件保存在ibd文件中,这个windows版本的工具测试后发现只能读取表结构,但不能读取视图,读取视图的frm需要用linux版本的dbsake

    记一次mysql根据.frm.ibd文件恢复数据

    当我发现我误操作drop了一张表之后,我从控制台上下载了备份的压缩包,解压之后拿到我drop的那张表(sys_users)的.frm.ibd文件 1:本地建一个相同的数据库(AA)和相同表结构的表(sys_users) (一定要一摸一样的表...

    使用ibdata和frm文件恢复MySQL数据库.docx

    使用ibdata和frm文件恢复MySQL数据库

    创建mysql表分区的方法

    表分区的测试使用,主要内容来自于其他博客文章以及mysql5.1的参考手册mysql测试版本:mysql5.5.28mysql物理存储文件(有mysql配置的datadir决定存储路径)格式简介数据库engine为MYISAMfrm表结构文件,myd表数据...

    恢复数据库_把后缀.frm,.myd,myi转换为.sql导入mysql数据库

    恢复数据库_把后缀.frm,.myd,myi转换为.sql导入mysql数据库

    frm文件结构恢复2.0.rar

    可以利用数据库的frm文件恢复表的结构语句,

    用VB制作按钮 .frm文件

    用VB做单选按钮的例子 .frm文件 包括属性 Cancel、Caption

    MYSQL使用.frm恢复数据表结构的实现方法

    我们都知道当我们建立数据表(innodb或myisam)时,会生成相应的文件(如:MYD,MYI,frm) 在这里,我们探讨下使用frm文件恢复 innodb和myisam类型表的结构,不过由于他们存储引擎的特性,所以恢复的方法也不一样,以下是...

Global site tag (gtag.js) - Google Analytics