mysql 数据库恢复步骤

注意:数据库名称保持一致,数据库编码保持一致,数据库引擎保持一致

### 数据库原有数据位置
    /var/lib/mysql/数据库名称/

### 数据库恢复步骤

#### 本步骤以数据库名称数据库和表名数据表为例

1. 创建与需要恢复的数据库名(以下简称恢复库)相同的数据库,如果类型是Innodb,创建的数据库也需为该类型:

   ```
   例: CREATE DATABASE IF NOT EXISTS 数据库名称 DEFAULT CHARSET utf8 COLLATE utf8_general_ci;
   
   (注:如果数据库类型不是Innodb,修改my.conf文件中的default-storage-engine=innodb,再重新创建数据库)
   ```

2. 创建与需要恢复的数据表名(以下简称恢复表)相同的数据表,字段数量必须与恢复表相同:

   ```
   use 数据库名称;
   
   create table 表名(id int,name varchar(20),age varchar(20),sex varchar(20)) engine=InnoDB default charset=utf8;
   ```

3. 关闭mysql服务,复制恢复表的frm文件到该数据库目录下,并修改其权限:

   ```
   sudo service mysqld stop/
   
   cp  表名.frm   数据库/表名.frm
   sudo chown mysql:mysql 表名.frm
   ```

4. 修改my.cnf文件配置,并重启mysql:

   ```
   修改my.cnf:
   innodb_force_recovery=4
   重启mysql:
   sudo service mysqld start
   ```

5. 查看恢复表的sql语句,并复制恢复表的创建语句:

   ```
   show create table 表名;
   ```

6. 删除恢复表,并使用上一步的创建语句重新创建该数据表,并分离数据表的frm和ibd文件:

   ```
   创建表的时候如果出现错误,修改my.cnf文件中的innodb_force_recovery=1,并重启mysql
   alter table 表名 DISCARD tablespace;
   ```

7. 复制恢复表的frm文件到该数据库目录下,并修改其权限:

   ```
   cp  表名.ibd   数据库/表名.ibd
   sudo chown mysql:mysql 表名.ibd
   ```

8. 恢复idb数据:

   ```
   alter table 表名 import tablespace;
   ```

   

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值