首页 > 学院 > 操作系统 > 正文

mysql数据库更新错误进行恢复

2024-06-28 16:01:14
字体:
来源:转载
供稿:网友

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条件,一定要在测试库上测试成功之后再进行操作,数据是一个公司的最重要的文件,请一定要重视。


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表