数据库的备份只有这样的*.frm,*.myd,*.myi文件怎么办?html
1.找到mysql的安装路径,找到my.ini文件,打开找到“datadir="C:/Program Files/MySQL/MySQL Server 5.0/Data/"”mysql
2.找到data文件夹,把备份的数据库(*.frm,*.myd,*.myi文件)复制到data目录下;sql
3.把备份数据库中的ibdata1文件也复制进来,需注意的是ibdata1文件若是覆盖掉以前的,以前库中的其余数据库则不可用,因此先建议把以前的库备份数据库
4.这样数据库就算恢复回来啦,若是出现有的表not exist,需注意ibdata1文件,多半是它的错服务器
补充知识点:
*.frm是描述了表的结构,*.MYD保存了表的数据记录,*.MYI则是表的索引
------------------------------------------------------------
注意事项:
尽量的保证新老服务器mysql的版本一致,字符编码一致
------------------------------------------------------------
其余:
导出*.sql文件大小问题,由于有些数据库限制大小,太大了的导入会出问题(对了导出后大于服务器限制的能够打成zip再导入)编码
---------------------------------------------------------------------------------spa
在MySQL数据库中,若是不指定innodb_file_per_table参数,单独存在每一个表的数据,MySQL的数据都会存放在ibdata1文件。
mysql ibdata1存放数据,索引等,是MYSQL的最主要的数据。命令行
步骤:日志
1,备份数据库orm
从命令行进入MySQL Server 5.1/bin
备份所有数据库,执行命令mysqldump -q -uusername -pyourpassword --add-drop-table --all-databases > /backup/all.sql
除数据库
drop database db1;
drop database db2;
此处不删除应用数据库,在全库恢复数据库时,就会报异常错误,一些表的*.ibd会报不存在。
解决方式:
movo db1 /backup/db1_bak
movo db2 /backup/db2_bak
作完此步后,而后中止数据库。
2,修改mysql配置文件
修改my.cnf文件,增长下面配置
innodb_file_per_table
对每张表使用单独的innoDB文件, 修改/etc/my.cnf文件
3,删除原数据文件
删除原来的ibdata1文件及日志文件ib_logfile*,删除data目录下的应用数据库文件夹(mysql,test,information_schema数据库自己文件夹不要删除)
4,还原数据库
启动数据库服务
从命令行进入MySQL Server 5.1/bin
还原所有数据库,执行命令mysql -uusername -pyourpassword < /all.sql
大公告成。
通过以上几步后,能够看到新的ibdata1文件就只有几十M了,数据及索引都变成了针对单个表的小ibd文件了,它们在相应数据库的文件夹下面。