Restore the mysql database from .frm files(从 .frm 文件恢复 mysql 数据库)
问题描述
我每周都转储我所有的桌子以获得备份.但后来我明白它只是存储表的 .frm 文件.它不显示表的 .MYD 和 .MYI 文件.所以我只有我的数据库的 .frm 文件,而且我的数据库是 innodb.那么我可以用数据库中的数据获取我的数据库吗?
I have dumped all my tables everyweek to got the backup. But later I understand that it is only storing the .frm file of the table. It is not showing .MYD and .MYI files of a table. So I have only my .frm file of the database with me and also mydatabase is innodb. So can I get my database with data in the database?
推荐答案
是的,这是可能的.仅将 .frm 文件复制到数据库文件夹还不够,还需要将 ib_logfiles 和 ibdata 文件复制到您的数据文件夹.我刚刚复制了 .frm 文件并复制了这些文件,然后重新启动服务器,我的数据库就恢复了.
Yes this is possible. It is not enough you just copy the .frm files to the to the databse folder but you also need to copy the ib_logfiles and ibdata file into your data folder. I have just copy the .frm files and copy those files and just restart the server and my database is restored.
复制以上文件后执行以下命令-
After copying the above files execute the following command -
sudo chown -R mysql:mysql/var/lib/mysql
sudo chown -R mysql:mysql /var/lib/mysql
上面的命令会将mysql下的文件所有者及其文件夹更改为MySql用户.这对于 mysql 读取 .frm 和 ibdata 文件很重要.
The above command will change the file owner under mysql and it's folder to MySql user. Which is important for mysql to read the .frm and ibdata files.
这篇关于从 .frm 文件恢复 mysql 数据库的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:从 .frm 文件恢复 mysql 数据库
基础教程推荐
- 从字符串 TSQL 中获取数字 2021-01-01
- ORA-01830:日期格式图片在转换整个输入字符串之前结束/选择日期查询的总和 2021-01-01
- 使用 VBS 和注册表来确定安装了哪个版本和 32 位 2021-01-01
- MySQL根据从其他列分组的值,对两列之间的值进行求和 2022-01-01
- CHECKSUM 和 CHECKSUM_AGG:算法是什么? 2021-01-01
- while 在触发器内循环以遍历 sql 中表的所有列 2022-01-01
- 如何在 CakePHP 3 中实现 INSERT ON DUPLICATE KEY UPDATE aka upsert? 2021-01-01
- 带更新的 sqlite CTE 2022-01-01
- MySQL 5.7参照时间戳生成日期列 2022-01-01
- 带有WHERE子句的LAG()函数 2022-01-01
