扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
1、首先构建测试环境数据create table t1(a varchar(10),b varchar(10));insert into t1 values('1','1');insert into t1 values('2','2');commit;。
为伊美等地区用户提供了全套网页设计制作服务,及伊美网站建设行业解决方案。主营业务为网站设计制作、网站设计、伊美网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!
2、模拟误修改,将t1表中的b字段更新为错误数据 "123456"update t1 set b='123456' where a='1';commit;select * from t1;。
3、将恢复工具上传到服务器并进行解压。unzip binlog2sql-master.zip。
4、得到误修改时的binlog文件(show binary logs;),实验环境是mysql-bin.000011。
5、通过 binlog2sql.py 脚本的到所有 对表 t1 的修改操作。python binlog2sql.py -hlocalhost -P23307 -ubinlog2sql -p'binlog2sql' -dtest -tt1 --start-file='mysql-bin.000011'。
6、得到了误删除的sql的准确位置在1382-1615之间,使用 _**-B**_ 选项生成回滚sql。python binlog2sql.py -hlocalhost -P23307 -ubinlog2sql -p'binlog2sql' -dtest -tt1 --start-file='mysql-bin.000011' --start-position=1382 --stop-position=1615 -B。
7、执行得到的回滚语句进行误操作恢复。就完成了。
mysql数据库不小心还原了需要按照以下步骤恢复。
1、先确认mysql有没有启用bin日志 ,就是看下mysql.ini(my.cnf)里的log-bin=mysql-bin, 可以 自定义一个目录和前缀名,比如/data/log/mylog这样。
2、然后在数据库文件存放的data目录就能看到mysql-bin.00000x这样的文件,这就是二进制日志了,可以导出成txt格式的,里面其实就是对数据库的各种操作sql语句。
3、导出txt文件:
e:\wamp\bin\mysql\mysql5.6.12\binmysqlbinlog
--database=testdatabase
e:\wamp\bin\mysql\mysql5.6.12\data\mysql-bin.000312
c:\\test1.txt
这是windows下的导出,linux也是类似的。
database=数据库名
从最早的日志还始还原
linux下可以很方便的 mysql-bin.000*
可以加参数开始时间和结束时间,就是你执行那条sql语句的时间
start-datetime="2014-12-04
11:25:56"
--stop-datetime="2014-12-04
13:23:50"
4、恢复数据:
e:\wamp\bin\mysql\mysql5.6.12\binmysqlbinlog
--database=yundongchao
e:\wamp\bin\mysql\mysql5.6.12\data\mysql-bin.000179
|
mysql
-u
root
-p
------------------------------------------------
1.第一步,查询语句:select*fromtable_name;或select*fromtable_namewhere条件,如下图。
2.第二步,增加语句或插入数据insertintotable_name(clus...)values(values...)实例如图
3.修改数据:updatetablenamesetxx=xx,xxx=xxwherexxx=xxxandxxx=xxx,如下图。
4.第四步,删除语句deletetable_namewhere条件实例如图。
1 找个别的机器安装个同版本的mysql或从已安装同版本的其他机器上(非同版本的也可以试下):
拷贝 mysql/data/mysql 目录到你的mysql/data/ 下吧
2 试着启动mysql服务,如果能启动了,理论上应该丢失的只有用户、授权等一些系统信息,不影响你的使用的数据;
如果不能启动,看错误日志,争取启动了。
3 赶紧把数据备份一份出来,重新把所有库(只是你后来创建的业务相关的库,不包括mysql库)都删了,重新导入一遍。理论上不这样也可以,但只是非生产重要的环境下。
4 重新做用户授权。
数据库误删某表恢复方法,这个前提是针对每天有备份的数据库 ,如果没有备份 恢复起来会非常非常麻烦,所以奉劝大家还是要备份!备份!备份!
/*首先查看一下数据表中的数据*/MariaDB [drop_test] select * from python_test;+----+-----------+------------+| id | name | class_time |+----+-----------+------------+| 1 | 字典 | 3 || 2 | 列表 | 2 || 3 | 函数 | 5 || 4 | 装饰器 | 2 || 5 | 迭代器 | 2 |+----+-----------+------------+5 rows in set (0.00 sec)
/*备份*/mysqldump -uroot -p111111 -B drop_test drop_test.sql
/*再插入数据后删除数据库*/MariaDB [drop_test] INSERT INTO python_test(id,name,class_time) value(6,'生成器',2);
Query OK, 1 row affected (0.01 sec)
MariaDB [drop_test] INSERT INTO python_test(id,name,class_time) value(7,'类的方法',5);
Query OK, 1 row affected (0.00 sec)
删除数据库
MariaDB [drop_test] drop database drop_test ;
Query OK, 1 row affected (0.01 sec)
切记这个时候不要有任何的操作!!!
/*这个时候要将当前的binlog日志拷贝到其他目录,以免后续操作对binlog日志产生影响*/cp /var/lib/mysql/mysql-bin.000006 /home
/*执行命令*/mysqlbinlog -d drop_test mysql-bin.000006 006bin.sql
编辑006bin.sql将里面的drop全部删除
最后则是开始恢复数据
/*首先恢复备份文件*/mysql -uroot -p111111 drop_test drop_test.sql
/*查看数据库备份文件*/MariaDB [(none)] show databases;+--------------------+| Database |+--------------------+| information_schema || drop_test || for_bak || lhc || mysql || performance_schema || test |+--------------------+7 rows in set (0.00 sec)/*备份的数据已经恢复了*/MariaDB [drop_test] show tables;+---------------------+| Tables_in_drop_test |+---------------------+| python_test |+---------------------+1 row in set (0.00 sec)
MariaDB [drop_test] select * from python_test;+----+-----------+------------+| id | name | class_time |+----+-----------+------------+| 1 | 字典 | 3 || 2 | 列表 | 2 || 3 | 函数 | 5 || 4 | 装饰器 | 2 || 5 | 迭代器 | 2 |+----+-----------+------------+5 rows in set (0.00 sec)
接下来恢复备份之后被删除的数据
mysql -uroot -p111111 drop_test 006bin.sql
/*恢复后查看数据*/MariaDB [drop_test] select * from python_test;+----+--------------+------------+| id | name | class_time |+----+--------------+------------+| 1 | 字典 | 3 || 2 | 列表 | 2 || 3 | 函数 | 5 || 4 | 装饰器 | 2 || 5 | 迭代器 | 2 || 6 | 生成器 | 2 || 7 | 类的方法 | 5 |+----+--------------+------------+7 rows in set (0.00 sec)
1 找个别的机器安装个同版本的mysql或从已安装同版本的其他机器上(非同版本的也可以试下):
拷贝 mysql/data/mysql 目录到你的mysql/data/ 下吧
2 试着启动mysql服务,如果能启动了,理论上应该丢失的只有用户、授权等一些系统信息,不影响你的使用的数据;
如果不能启动,看错误日志,争取启动了。
3 赶紧把数据备份一份出来,重新把所有库(只是你后来创建的业务相关的库,不包括mysql库)都删了,重新导入一遍。理论上不这样也可以,但只是非生产重要的环境下。
4 重新做用户授权。
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流