首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL】MyFlash mysql binlog

简介: 数据库运行过程中难免会发生误操作,特别是在测试环境 开发人员或测试人员有时会误删或者更新错误某些数据。这时可以用binlog闪DML操作。...本篇文章主要介绍通过MyFlash工具来回binlog。 MyFlash是由美团点评公司技术工程部开发维护的一个DML操作的工具。该工具通过解析v4版本的binlog,完成操作。...相对已有的工具,其增加了更多的过滤选项,让更加容易。...3.start-position 指定滚开始的位置。如不指定,从文件的开始处。请指定正确的有效的位置,否则无法 4.stop-position 指定结束的位置。如不指定,滚到文件结尾。...请指定正确的有效的位置,否则无法 5.start-datetime 指定的开始时间。注意格式必须是 %Y-%m-%d %H:%M:%S。

3.9K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql binlog数据

    1.先开启binlog log-bin = /var/log/mysql/mysql_bin #binlog日志文件,以mysql_bin开头,六个数字结尾的文件:mysql_bin.000001,并且会将文件存储在相应的...xxx/xxx路径下,如果只配置mysql_bin的话默认在C:\ProgramData\MySQL\MySQL Server 5.7\Data下; binlog_format = ROW #binlog...日志格式,默认为STATEMENT:每一条SQL语句都会被记录;ROW:仅记录哪条数据修改并且修改成什么样子,是binlog开启并且能恢复数据的关键; expire_logs_days= 10 #binlog...4.进入mysql查看一下开始和结束的pos位置,第一个框是删除,下面的是更新,开始位置和结束位置219--498 563---881 ?...show binlog events in 'mysql-bin.000352' 5.用binlog2sql打印出sql语句和逆向的sql语句,保存并导入 python binlog2sql.py

    5.9K20

    MyFlash mysql binlog

    简介:MyFlash是由美团点评公司技术工程部开发维护的一个DML操作的工具。该工具通过解析v4版本的binlog,完成操作。相对已有的工具,其增加了更多的过滤选项,让更加容易。...3.start-position 指定滚开始的位置。如不指定,从文件的开始处。请指定正确的有效的位置,否则无法 4.stop-position 指定结束的位置。如不指定,滚到文件结尾。...请指定正确的有效的位置,否则无法 5.start-datetime 指定的开始时间。注意格式必须是 %Y-%m-%d %H:%M:%S。...如不指定,则不限定时间 6.stop-datetime 指定的结束时间。注意格式必须是 %Y-%m-%d %H:%M:%S。...8.maxSplitSize 一旦指定该参数,对文件进行固定尺寸的分割(单位为M),过滤条件有效,但不进行操作。

    1.5K20

    MySQL 日志 undo log

    事务日志分为undo log(日志) 和 redo log(重做日志) 二、undo log 1. undo log的概念 undo log和redo log统称事务日志,不同于binlog是MySQL...出现异常时(如数据持久化过程断电),重启后InnoDB会使用redo log恢复到断电前的状态,保证数据的完整性 undo log:日志,保存了事务发生之前的数据的一个版本,用于事务的操作,同时也是实现多版本并发控制...(MVCC)下读操作(快照读)的关键技术 2. undo log的作用 undo log日志的主要作用: 事务发生错误时rollback,数据更新之前,会把原始数据保存在日志中,保证事务出错或者我们手动的时候...事务开启请求发到MySQL server上,MySQL server为每个事务都会分配一个全局的,不冲突的事务ID(InnoDB存储引擎分配的,因为它才支持事务)。...防止事务恢复修改前的状态,需要将最初的数据存放在undo log中!

    24530

    mysql事务机制概述

    ROLLBACK:也可以使用ROLLBACK WORK,两者也是等价的,会结束用户的事务,并且会撤销正在进行的所有未提交的修改。...事务T2读取到了T1更新后的行,然后T1执行操作,取消了刚才所做的修改。...mysql事务怎样实现的代码可以参考此bolg:http://bbs.csdn.net/topics/390876901 要同时修改数据库中两个不同表时,如果它们不是一个事务的话,当第一个表修改完...,可能第二个表修改过程中出现了异常而没能修改,此时就只有第二个表依旧是未修改之前的状态, 而第一个表已经修改完毕。...而当你把它们设定为一个事务的时候,当第一个表修改完,第二表修改出现异常而没能修改,第一个表和第二个表都要回到未修改的状态,这就是所谓的事务

    2.7K20

    MySQL--事务机制与原理

    事务机制 其实,讨论MySQL的事务机制,也就是在说MySQL的事务原子性是如何实现的(关于事务之前文章中有过简单介绍)。...实现原理 在说明原理之前,需要首先介绍一下MySQL的事务日志。...MySQL的日志有很多种,如二进制日志、错误日志、查询日志、慢查询日志等,此外InnDB引擎还提供了两种事务日志:redo log(重做日志)和undo log(日志)。...以update操作为例:当事务执行update时,其生成的undo log中会包含修改行的主键(以便知道修改了哪些行)、修改了哪些列、这些列在修改前后的值等信息,时便可以使用这些信息将数据还原到update...过程如下: 参考:https://blog.csdn.net/m0_49449205/article/details/114988580

    2.9K20

    mysql事务机制概述「建议收藏」

    ROLLBACK:也可以使用ROLLBACK WORK,两者也是等价的,会结束用户的事务,并且会撤销正在进行的所有未提交的修改。...事务T2读取到了T1更新后的行,然后T1执行操作,取消了刚才所做的修改。...mysql事务怎样实现的代码可以参考此bolg:http://bbs.csdn.net/topics/390876901 要同时修改数据库中两个不同表时,如果它们不是一个事务的话,当第一个表修改完...,可能第二个表修改过程中出现了异常而没能修改,此时就只有第二个表依旧是未修改之前的状态, 而第一个表已经修改完毕。...而当你把它们设定为一个事务的时候,当第一个表修改完,第二表修改出现异常而没能修改,第一个表和第二个表都要回到未修改的状态,这就是所谓的事务

    2.6K10

    MySQL事务部分-滚到指定保存点「建议收藏」

    我们可以在mysql事务处理过程中定义保存点(SAVEPOINT),然后滚到指定的保存点前的状态。 定义保存点,以及滚到指定保存点前状态的语法如下。...定义保存点—SAVEPOINT 保存点名; 滚到指定保存点—ROLLBACK TO SAVEPOINT 保存点名: 下面演示将向表user中连续插入3条数据,在插入第2条数据的后面定义一个保存点,最后看看能否滚到此保存点...事务开始 mysql> BEGIN; Query OK, 0 rows affected (0.00 sec) 3、向表user中插入2条数据 mysql> INSERT INTO user VALUES...| 3 | one | 0 | | | 4 | two | 0 | | | 5 | three | 0 | | +—–+———-+—–+——+ 5 rows in set (0.02 sec) 6、滚到保存点...test mysql> ROLLBACK TO SAVEPOINT test; Query OK, 0 rows affected (0.31 sec) mysql> select * from user

    2K30

    MySQL】通过Binary Log简单实现数据(一)

    前段时间,工作项目上出于对excel等批量操作可能出现误操作的问题,要求提供一个能够根据操作批次进行数据的能力。在开发的过程中接触到了MySQL的Binary Log,感觉有些收获,记录一下。...MySQL的时候默认只给了mysql用户,所以要加-u切换成mysql。...可变大小:用bit来表示是否每列使用,一个bit一列,如果N个列,要用INT((N+7)/8)字节 可变大小(针对UPDATE_ROWS_LOG_EVENT),与上面相同,表示的是更新后每列是否使用...根据不同选项,你可以得到原始SQL、SQL、去除主键的INSERT SQL等。...o(TωT)o  五、总结 第一部分先记录一下整个操作的过程,第二部分写具体的实现过程。谢谢各位园友观看,如果有描述不对的地方欢迎指正,与大家共同进步!

    1.5K110

    MySQL 死锁后事务无法是真的吗?

    MySQL 作为目前互联网企业使用最多的,或者说在基于成本下,最流行的数据库之一,MySQL 在国内使用者众多,那么在MySQL偶然安装后,在使用中出现死锁后,死锁中的事务到底能不能 ?...MySQL 在处理事务的和存储过程的建议,或者说民间使用MySQL的建议,不建议大事务,不建议存储过程大量的在业务中使用的这个‘口耳相传’的论调,找寻到一些最初MySQL 设计出来的最初的初衷。...当然事务不完全对于使用者本身是不是一个问题,具体我们需要看业务的设定是不是允许或接受,如同MySQL 本身也在表设计时也不希望遵循 三范式一样。MySQL 是一个反传统的数据库产品。...经过我们的调整MySQL的参数后,MySQL 满足了我们传统的数据库对于事务中的要求,要么全,要么全不回。...A 和 B 事务代码,事务A 中的插入是没有生效的,从而证明MySQL 完全可以实现在死锁后死锁事务的全部

    36341

    MySQL】通过Binary Log简单实现数据(一)

    前段时间,工作项目上出于对excel等批量操作可能出现误操作的问题,要求提供一个能够根据操作批次进行数据的能力。...在开发的过程中接触到了MySQL的Binary Log,感觉有些收获,记录一下。...可变大小:用bit来表示是否每列使用,一个bit一列,如果N个列,要用INT((N+7)/8)字节 可变大小(针对UPDATE_ROWS_LOG_EVENT),与上面相同,表示的是更新后每列是否使用...根据不同选项,你可以得到原始SQL、SQL、去除主键的INSERT SQL等。...o(TωT)o  ​ 五、总结 第一部分先记录一下整个操作的过程,第二部分写具体的实现过程。谢谢各位园友观看,如果有描述不对的地方欢迎指正,与大家共同进步!

    1.7K70

    MySQL 核心模块揭秘 | 14 期 | 整个事务

    整个事务时,事务执行过程中改变(插入、更新、删除)的数据都不要了,产生的 binlog 日志也就没有用了。 整个事务,首先要进行的步骤就是 binlog 。...过程中,会根据 undo 日志产生的时间,从后往前读取并解析日志,再执行这条日志对应的操作。 示例 SQL 中,执行了两条 insert 语句,会产生两条 undo 日志,编号分别为 0、1。...前面的 binlog 步骤,没有清除事务执行过程中产生的 binlog 日志,而是留到 InnoDB 步骤中提交事务完成之后才执行。...这是因为: 清空磁盘临时文件中 binlog 日志的过程不可逆,如果中间出现问题,不能回退。 InnoDB 步骤中提交事务的容错性更好,失败之后就不清除 binlog 日志了,也不损失什么。...第 2 步,执行 InnoDB 操作,会把事务执行过程中改变(插入、更新、删除)的记录恢复原样(至少从逻辑上来看是这样的)。 最后,还会提交 InnoDB 事务,让操作对数据页的修改生效。

    13210

    Oracle数据库,详解Oracle数据过程

    1、 事务开始; 2、 在buffer cache中找到需要的数据块,如果没有找到,则从数据文件中载入buffer cache中; 3、 事务修改buffer cache的数据块,该数据标识为“脏数据...”,并写入log buffer中; 4、 事务提交,LGWR进程将log buffer中的“脏数据”写入redo log file中; 5、 当发生checkpoint,CKPT进程更新所有数据文件的文件头中的信息...最近在修复一个比较老的项目报表的bug的时候,因为对该项目不太熟悉,导致生产环境数据修改有误,查了资料做了数据,现学习一下Oralce数据以备不时之需。 查看某个时间点的表的数据 ?...开启闪,如果不开启无法进行闪 ? 关闭闪数据之后需要进行关闭 ? 闪表数据到某个时间点 ? drop表 ? 查询数据库回收站记录 ?...如果相隔时间过长的话,数据就回不了了,所以一旦数据出现问题,就要立即进行处理。 ?

    1.5K20

    图文结合带你搞定MySQL日志之Undo log(日志)

    情况二:DBA可以在事务执行过程中手动输入ROLLBACK语句结束当前事务的执行。以上情况出现,我们需要把数据改回原先的样子,这个过程称之为。...(对于每个UPDATE,InnoDB存储引擎会执行一个相反的UPDATE,将修改前的行放回去) MySQL把这些为了而记录的这些内容称之为撤销日志或者回日志(即Undo Log)。...2.当一个事务开始的时候,会制定一个段,在事务进行的过程中,当数据修改时,原始的数据会被复制到段。 3.在段中,事务会不断填充盘区,直到事务结束或所有的空间用完。...未提交的数据(uncommitted undo information):该数据所关联的事务并未提交,用于实现读一致性,所以该数据不能其他事务的数据覆盖。...Undo Log的工作原理 在更新数据之前,MySQL会提前生成Undo Log日志,当事务提交的时候,并不会立即删除Undo Log,因为后面可能需要进行操作,要执行(ROLLBACK)操作时

    2.4K30

    2020-12-15:mysql机制是怎么实现的?

    福哥答案2020-12-15: 答案来自此链接: 在 MySQL 中,恢复机制是通过日志(undo log)实现的,所有事务进行的修改都会先记录到这个日志中,然后在对数据库中的对应行进行写入。...MySQL的事务是有redo和undo的,redo操作的所有信息都是记录到 redo_log中,也就是说当一个事务做commit操作时,需要先把这个事务的操作写到redo_log中,然后再把这些操作flush...而对于undo就比较麻烦,MySQL在处理事务时,会在数据共享 表空间里申请一个段叫做segment段,用保存undo信息,当在处理rollback,不是完完全全的物理undo,而是逻辑undo,就是说会对之...这些表空间的回收需要由mysql的master thread进程来进行回收。

    90010
    领券