是否可以从物理数据库文件还原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