日期:2014-05-16  浏览次数:20854 次

通过拷贝frm myd myi opt文件来实现mysql的备份和还原

不知道大家有没有想过,我们向mysql数据库中写入了数据,这些数据存放在什么地方。在linux下手动编译安装过mysql的人,我想 会知道存放在什么地方,mysql_install_db有这一步操作,他是产生mysql自带的数据库,执行了这一步操作后,你可以到/mysql安装目录/data(这个数据目录,可以从my.cnf中查到datadir) 目录下面就会出一个mysql的文件夹。

一,frm myd myi opt的解释

1,.frm保存的是描述了表的结构

?

2,.MYD保存的是表的数据记录

3,.MYI保存的是表的索引?

4,.opt保存的是数据库的字符集

[root@BlackGhost test]# ls |grep opt | xargs cat
default-character-set=utf8
default-collation=utf8_general_ci

二,备份数据库

创建一个数据库,create database test; 这个时候去data目录下 面看看,会产生一个test文件夹 ,里面只有一个db.opt 文件,然后你在创建一些表,添加一些数据后,你在去data/test下面看看,里面多了一些.frm,.myd的文件

tar czvf /home/databak/test.tar.gz /usr/local/mysq/data/test

这样就备份好了

三,还原数据库

1,进入test数据库

use test;
show tables;

在这儿你会看到,你新增加的表。

2,删除data/test目录下面的frm,myd,myi这三种类型的文件

use test;
show tables;

这个时候,一张表都没有。

3,还原表

tar zxvf /home/databak/test.tar.gz -C /usr/local/mysq/data

4,在查看test的表

use test;
show tables;

这个时候,新增加的表又出来了。

如果是直接把data下面的test目录删除掉的话,就重新create database test; 会产生一个新的test目录,然后在把备份的数据,还原过来就行了。个人觉得这种备份比较好,导出,导入比较麻烦,不用记得备份命令,只要会copy就行了。在不改变数据库配置的前提下,这种备份,还原基本上不会出现乱码的。