mysql 从物理文件恢复_关于备份:从物理文件还原MySQL数据库

本文介绍了如何从MySQL的物理文件恢复数据库,包括FRM、MYD和MYI文件的作用。针对MyISAM表,可以通过复制文件到数据库文件夹并在服务未运行时执行恢复。而对于InnoDB表,恢复过程更复杂,需要ibdata1、ib_logfile等文件。恢复时需要注意文件权限和所有权,确保服务器可以正确访问。若服务器正在运行,可能需要停服操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

是否可以从物理数据库文件还原MySQL数据库。 我的目录具有以下文件类型:

client.frm

客户端

客户

但要多出约20张桌子。

我通常使用mysqldump或类似的工具在1个SQL文件中获取所有内容,那么如何处理这些类型的文件呢?

我有一个相同的问题:扩展名为FRM,MYD和MYI的多个文件。 我也有文件ib_logfile0,ib_logfile1和ibdata1。 我无法访问正在运行的服务器或创建转储。 我尝试运行新的MySQL服务器并使用这些文件,但我没有发现...有人有明确的操作方法吗?

MySQL MyISAM表是三个文件的组合:

FRM文件是表定义。

MYD文件是存储实际数据的位置。

MYI文件是存储在表上创建的索引的位置。

您应该能够通过将它们复制到数据库文件夹中来进行还原(在linux中,默认位置为/var/lib/mysql/)

您应该在服务器未运行时执行此操作。

这仅对于MyISAM表是正确的。 InnoDB将其表和索引存储在单个表空间*中,该表空间默认情况下由3个文件ibdata1,ib_logfile0和ib_logfile1组成。要还原数据库,您还需要这些文件。 *每表表空间是可能的,但不是默认值

他说他有.frm .myi和.myd文件。然后我以为是MyISAM表。

正确点-)

@ax是否可以在没有ibdata的情况下从InnoDB获取数据?我有一个月大的备份,并且只有当前的ib_logfile *和.frm文件。

@ax您添加了信息以使此问题更笼统,我确实复制了frm etc文件,但没有复制ibd

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值