一起学习网 一起学习网

简单易懂,直击主题:MySQL回滚SQL(mysql回滚sql)

MySQL回滚SQL是用来恢复MySQL数据库到一个早先的状态的功能,主要是用来保护数据库的完整性。在业务过程中,我们总是会碰到数据的修改,在数据的修改发生时,就需要做到修改前后可以实现回滚。 MySQL提供了回滚SQL的功能,可以帮助做到数据安全防止数据丢失。

MySQL回滚SQL需要完全满足 3W2H (即: What, When, Where, Who, How)的执行,也就是说,要知道什么改动,何时改动,改动哪里,是谁改动的,以及怎么改动的。

一般来说,MySQL,回滚SQL有两种形式,一种是事务操作,也就是事务SQL。另一种是使用MySQL binlog工具创建的binlog日志,通过恢复binlog实现回滚的SQL操作。

另外,MySQL的binlog大小不可以太小,一般要配置为至少2M以上,否则会出现binlog大小不足,无法回滚的情况。

针对实时数据,MySQL可以使用事务SQL实现回滚操作, 例如:

begin;
update table_name set xxxx = xxxx;
commit;
-- 回滚
begin;
rollback;

针对历史数据,MySQL可以使用binlog日志实现回滚操作, 例如:

mysql --user=username –password=123456
mysql>RESET MASTER;
mysql>PURGE BINARY LOGS BEFORE now;
mysql>FLUSH LOGS;
mysql> SET GLOBAL sql_log_bin = 0;
mysql>RESET MASTER;
mysql> SET GLOBAL sql_log_bin = 1;
mysql>FLUSH LOGS;

以上就是MySQL回滚SQL的简单介绍了,MySQL的回滚SQL会在业务过程中非常实用,一般会使用某个可用的备份文件或者binlog工具进行备份;我们在发生更改时,都可以通过上述的步骤实现回滚的功能。