mysql数据库更新错误进行恢复 - shenBML的博客 - CSDN博客

MySql数据库恢复
1、 系统说明:
数据库版本:MySql5.6.34
操作系统:CentOS release 6.8 (Final)
数据库编码:utf8
数据库故障描述:测试库中更新某个字段,但是没有加where 条件,导致某个列全部更新为同一值。
select * from test
-> ;
+—-+———–+
| id | name |
+—-+———–+
| 1 | 孙立人 |
| 2 | 薛岳 |
| 3 | 李宗仁 |
| 4 | 林彪 |
| 5 | 白崇禧 |
| 6 | 廖耀湘 |
| 7 | 巴顿 |
| 8 | 蒋介石 |
| 9 | 国民党 |
| 10 | 胡适 |
+—-+———–+
10 rows in set (0.00 sec)

update test set name =’毛泽东’;
Query OK, 10 rows affected (0.01 sec)
Rows matched: 10 Changed: 10 Warnings: 0

mysql> select * from test;
+—-+———–+
| id | name |
+—-+———–+
| 1 | 毛泽东 |
| 2 | 毛泽东 |
| 3 | 毛泽东 |
| 4 | 毛泽东 |
| 5 | 毛泽东 |
| 6 | 毛泽东 |
| 7 | 毛泽东 |
| 8 | 毛泽东 |
| 9 | 毛泽东 |
| 10 | 毛泽东 |
+—-+———–+
10 rows in set (0.00 sec)
2、 查看binlog日志是否开启:
在my.cnf中的[mysqld]域中
看到已经开启日志:

[mysqld]

Remove leading # and set to the amount of RAM for the most important data

cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%.

innodb_buffer_pool_size = 128M

Remove leading # to turn on a very important data integrity option: logging

changes to the binary log between backups.

log_bin

log_bin=mysqlbin_oldboy
3、 查看数据库存放位置中的日志文件:
cd /data/mysql
-rw-rw—-. 1 mysql mysql 56 1月 20 00:14 auto.cnf
-rw-r–r–. 1 root root 4412 2月 8 16:05 bintest.sql
-rw-rw—-. 1 mysql mysql 12582912 2月 8 16:06 ibdata1
-rw-rw—-. 1 mysql mysql 50331648 2月 8 16:06 ib_logfile0
-rw-rw—-. 1 mysql mysql 50331648 1月 20 00:13 ib_logfile1
drwx——. 2 mysql mysql 4096 1月 20 00:14 mysql
-rw-rw—-. 1 mysql mysql 3068 2月 8 16:06 mysqlbin_oldboy.000001
-rw-rw—-. 1 mysql mysql 25 2月 8 00:45 mysqlbin_oldboy.index
srwxrwxrwx. 1 mysql mysql 0 2月 8 00:45 mysql.sock
drwx——. 2 mysql mysql 4096 2月 7 22:58 oldboy
drwx——. 2 mysql mysql 4096 2月 7 22:39 oldgirl
drwx——. 2 mysql mysql 4096 1月 20 00:14 performance_schema
drwx——. 2 mysql mysql 4096 2月 8 00:17 test
-rw-r—–. 1 mysql root 44363 2月 8 15:42 web1.err
-rw-rw—-. 1 mysql mysql 7 2月 8 00:45 web1.pid

标红地方就是我们要使用的日志文件。
使用mysqlbinlog命令把mysqlbin_oldboy.000001转换成sql文件,
mysqlbinlog -d test mysqlbin_oldboy.000001 >bin.sql
说明:-d 指定数据库
[root@web1 mysql]# ll
总用量 110696
-rw-rw—-. 1 mysql mysql 56 1月 20 00:14 auto.cnf
-rw-r–r–. 1 root root 7707 2月 8 16:28 bin.sql
-rw-r–r–. 1 root root 4412 2月 8 16:05 bintest.sql
-rw-rw—-. 1 mysql mysql 12582912 2月 8 16:25 ibdata1
-rw-rw—-. 1 mysql mysql 50331648 2月 8 16:25 ib_logfile0
-rw-rw—-. 1 mysql mysql 50331648 1月 20 00:13 ib_logfile1
drwx——. 2 mysql mysql 4096 1月 23 22:50 mydx
drwx——. 2 mysql mysql 4096 1月 20 00:14 mysql
-rw-rw—-. 1 mysql mysql 3285 2月 8 16:25 mysqlbin_oldboy.000001
-rw-rw—-. 1 mysql mysql 25 2月 8 00:45 mysqlbin_oldboy.index
srwxrwxrwx. 1 mysql mysql 0 2月 8 00:45 mysql.sock
drwx——. 2 mysql mysql 4096 2月 7 22:58 oldboy
drwx——. 2 mysql mysql 4096 2月 7 22:39 oldgirl
drwx——. 2 mysql mysql 4096 1月 20 00:14 performance_schema
drwx——. 2 mysql mysql 4096 2月 8 00:17 test
-rw-r—–. 1 mysql root 44363 2月 8 15:42 web1.err
-rw-rw—-. 1 mysql mysql 7 2月 8 00:45 web1.pid

编辑bin.sql文件
vim bin.sql
# at 3147

170208 16:25:52 server id 1 end_log_pos 3254 CRC32 0xa4ab5836 Query thread_id=2 exec_time=0 error_code=0

SET TIMESTAMP=1486542352/_!_/;

**update test set name ='毛泽东'  删除这一行**

/_!_/;

at 3254

然后进行恢复:
[root@web1 mysql]# mysql -uroot -p test -e “select * from test;”
Enter password:
+—-+———–+
| id | name |
+—-+———–+
| 1 | 毛泽东 |
| 2 | 毛泽东 |
| 3 | 毛泽东 |
| 4 | 毛泽东 |
| 5 | 毛泽东 |
| 6 | 毛泽东 |
| 7 | 巴顿 |
| 8 | 蒋介石 |
| 9 | 国民党 |
| 10 | 胡适 |
+—-+———–+

之所以看到1-6还是毛泽东,那是因为我之前没有开启binlog日志,现在看到mysql开启日志的重要性了吧!

总结:
mysql数据更新的时候一定要带上where条件,一定要在测试库上测试成功之后再进行操作,数据是一个公司的最重要的文件,请一定要重视。


Original url: Access
Created at: 2018-10-24 00:37:26
Category: default
Tags: none

请先后发表评论
  • 最新评论
  • 总共0条评论