MySQL数据库被修改后的恢复方法

数据库
MySQL数据库可能存在被修改的危险,有些可能不是故意的修改,有的可能是故意进行恶意破坏的,那么我们就要对被修改的数据库进行恢复,下文中将为大家介绍数据库恢复的方法。

MySQL数据库的恢复,之前已经为大家介绍了MySQL数据库中数据被删除后的恢复,本文为大家介绍另外一种恢复的情况,即MySQL数据库被修改后的恢复。

当数据库被修改后的恢复方法:

数据库被修改,可能存在着多方面的原因,被入侵、以及相应程序存在Bug等等,这里不作详细介绍。这里将只介绍在数据库被修改后,如果恢复到被修改前状态的方法。

具体和上面所述的“数据库被删除后的恢复方法”相类似。这里,测试用数据库接着使用刚刚在前面用过的test。这里为了使刚刚接触数据库的朋友不至于理解混乱,我们再次登录到MySQL服务器上确认一下刚刚建立的测试用的数据库test的相关信息。

[root@CentOS ~]# mysql -u root -p  ← 用root登录到MySQL服务器
Enter password:  ← 输入MySQL的root用户密码
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 14 to server version: 4.1.20

Type 'help;' or '\h' for help. Type '\c' to clear the buffer.

mysql> show databases;  ← 查看当前存在的数据库
+-------------+
| Database |
+-------------+
| mysql |
| test  |
+------------+
2 rows in set (0.00 sec)

mysql> use test  ← 连接到test数据库
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> show tables;  ← 查看test数据库中存在的表
+-------------------+
| Tables_in_test |
+-------------------+
| test  |
+-------------------+
1 row in set (0.00 sec)

mysql> select * from test;  ← 查看数据库中的内容
+------+--------------------+
| num | name  |
+------+--------------------+
| 1 | Hello,CentOS|
+------+--------------------+
1 row in set (0.01 sec)

mysql> exit  ← 退出MySQL服务器
Bye

然后,我们再次运行数据库备份脚本,将当前状态的数据库,再做一次备份。

[root@CentOS ~]# cd  ← 回到脚本所在的root用户的根目录
[root@CentOS ~]# ./mysql-backup.sh  ← 运行脚本进行数据库备份
接下来,我们再次登录到MySQL服务器中,对测试用的数据库test进行一些修改,以便于测试数据恢复能否成功。

[root@sample ~]# mysql -u root -p  ← 用root登录到MySQL服务器
Enter password:  ← 输入MySQL的root用户密码
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 15 to server version: 4.1.20

Type 'help;' or '\h' for help. Type '\c' to clear the buffer.

mysql> use test  ← 连接到test数据库
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> update test set name='Shit,Windows';  ← 然后将test中表的值重新定义为“Shit,Windows”(原来为“Hello,CentOS”)
Query OK, 1 row affected (0.07 sec)
Rows matched: 1 Changed: 1 Warnings: 0

mysql> select * from test;  ← 确认test中的表被定义的值
+------+--------------------+
| num | name  |
+------+-------------------+
| 1 | Shit,Windows |  ← 确认已经将原test数据库表中的值修改为新的值“Shit,Windows”
+------+-------------------+
1 row in set (0.00 sec)

mysql> exit  ← 退出MySQL服务器
Bye

以上,我们就等于模拟了数据库被篡改的过程。接下来,是数据库被“篡改”后,用备份进行恢复的方法。

[root@CentOS ~]# /bin/cp -Rf /backup/mysql/test/ /var/lib/mysql/  ← 复制备份的数据库test到相应目录


然后,再次登录到MySQL服务器上,看数据库是否被恢复到了被“篡改”之前的状态。

[root@CentOS ~]# mysql -u root -p  ← 用root登录到MySQL服务器
Enter password:  ← 输入MySQL的root用户密码
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 16 to server version: 4.1.20

Type 'help;' or '\h' for help. Type '\c' to clear the buffer.

mysql> use test  ← 连接到test数据库
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> select * from test;  ← 查看数据库中的内容
+------+----------------+
| num | name  |
+------+----------------+
| 1| Hello,CentOS | ← 确认数据表中的内容与被修改前定义的“Hello,CentOS”一样!
+------+----------------+
1 row in set (0.01 sec)

mysql> exit  ← 退出MySQL服务器
Bye


以上结果表示,数据库被修改后,用备份后的数据库成功的将数据恢复到了被“篡改”前的状态。

测试后…

测试完成后,将测试用过的遗留信息删除。

[root@CentOS ~]# mysql -u root -p  ← 用root登录到MySQL服务器
Enter password:  ← 输入MySQL的root用户密码
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 19 to server version: 4.1.20

Type 'help;' or '\h' for help. Type '\c' to clear the buffer.

mysql> use test  ← 连接到test数据库
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> drop table test;  ← 删除test数据库中的表
Query OK, 0 rows affected (0.01 sec)

mysql> drop database test;  ← 删除测试用数据库test
Query OK, 0 rows affected (0.00 sec)

mysql> show databases;  ← 查看当前存在的数据库
+-------------+
| Database |
+-------------+
| mysql |  ← 确认测试用数据库test不存在、已被删除
+-------------+
1 row in set (0.00 sec)

mysql> exit  ← 退出MySQL服务器
Bye

如果大家以后在工作中遇到MySQL数据库被修改,通过本文的学习,到时候就能很轻松的应对,利用上文中介绍的进行数据库的恢复。

【编辑推荐】

  1. MySQL数据库中数据被删除后的恢复
  2. MySQL数据库的自动备份
  3. 两大步骤教您开启MySQL数据库远程登陆帐号
责任编辑:迎迎 来源: 中国站长站综合
相关推荐

2011-02-28 13:31:17

Oracle数据库

2011-04-12 15:44:08

Oracle数据库

2011-05-13 13:15:52

SYBASE ASA数

2011-03-30 14:08:27

MySQL数据库删除恢复

2011-08-02 16:03:47

Oracle数据库冷备份冷备份异地恢复

2010-08-16 16:17:46

DB2数据库备份参数

2010-11-15 15:34:30

ORACLE数据库恢复

2019-08-20 14:02:07

MongoDB数据库恢复数据

2018-04-28 15:28:44

数据库MySQL误删除

2010-06-09 15:40:59

MySQL数据库文件

2018-05-17 17:05:05

Linux

2011-08-05 10:24:48

MySQL数据库myisamchk

2010-07-02 09:36:30

SQL Server

2010-05-04 09:36:02

Unix文件

2019-10-08 09:49:57

数据库备份恢复

2010-07-19 15:21:03

Win2000 Tel

2011-04-07 09:06:27

MySQL数据库密码

2010-11-02 10:27:38

DB2分区数据库恢复

2010-08-04 14:38:34

路由器密码

2010-09-02 14:04:20

点赞
收藏

51CTO技术栈公众号