国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 操作系統 > 正文

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條件,一定要在測試庫上測試成功之后再進行操作,數據是一個公司的最重要的文件,請一定要重視。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 阳朔县| 吉隆县| 麻栗坡县| 乐昌市| 东乌| 乌鲁木齐县| 临湘市| 和龙市| 池州市| 吴川市| 同仁县| 安泽县| 福清市| 仪征市| 光泽县| 迭部县| 防城港市| 澎湖县| 察雅县| 来宾市| 岑溪市| 关岭| 越西县| 南部县| 霍林郭勒市| 富川| 宿迁市| 鸡西市| 车险| 陈巴尔虎旗| 吉林省| 舒城县| 乳源| 天柱县| 桂东县| 漳浦县| 绿春县| 汤阴县| 五家渠市| 兴业县| 南投市|