<p>mysqlbinlog 默认输出 base64 是因为 MySQL 5.6+ 默认 binlog_format=ROW,记录行变更二进制事件;需加 –base64-output=DECODE-ROWS 和 - v 参数才能解析为可读的伪 SQL(如 ### UPDATE…),但不可直接执行。</p>

mysqlbinlog 读出来的为什么全是 base64?
因为 MySQL 5.6+ 默认启用 binlog_format = ROW,此时 binlog 不存原始 SQL,而是记录行变更的二进制事件(Write_rows_log_event 等),mysqlbinlog 为避免乱码或解析失败,直接把事件体转成 base64 输出。
这不是 bug,是设计行为。想看到可读 SQL,得让 MySQL 记录语句级日志,或让 mysqlbinlog 尝试反解 ROW 事件(有限支持)。
-
binlog_format = STATEMENT时,mysqlbinlog直接输出原始 SQL(但不推荐,兼容性和一致性风险高) -
binlog_format = MIXED多数情况也走 STATEMENT,但某些函数 /DDL 会自动切到 ROW -
binlog_format = ROW是默认且推荐模式,但必须配合--base64-output=DECODE-ROWS+-v才能还原出伪 SQL(如### UPDATE …… WHERE @1=1)
用 mysqlbinlog 解析 ROW 格式 binlog 的正确姿势
直接跑 mysqlbinlog mysql-bin.000001 只能看到 base64 和一堆 # at 123,没用。关键参数就两个:--base64-output=DECODE-ROWS 和 -v(或 --verbose),缺一不可。
-
--base64-output=DECODE-ROWS告诉工具:别只 dump base64,遇到 ROW 事件试着拆成“伪 SQL”格式 -
-v是触发解码的开关,不加它,--base64-output=DECODE-ROWS会被忽略 - 再加一个
-v(即-vv)会显示更多字段类型和元数据,但通常没必要 - 如果 binlog 文件权限不对,会报错
Failed to open file 'mysql-bin.000001',确认路径、用户权限、是否被 mysqld 占用
示例命令:
mysqlbinlog --base64-output=DECODE-ROWS -v mysql-bin.000001
看到的“### UPDATE …… WHERE @1=1”是什么?能直接执行吗?
这是 mysqlbinlog -v 对 ROW 事件的“逆向工程”结果,不是真实执行过的 SQL。@1、@2 是列值占位符,对应表结构里的第 1、2 列,顺序由 CREATE TABLE 语句定义,不是 SELECT 出来的顺序。
- 它不能直接复制粘贴进 MySQL 执行——
@1不是变量,MySQL 会报错Unknown system variable '@1' - 它的作用是帮你定位:哪张表、哪几行、改了哪些字段。比如
### SET @1=100, @2='new_name'表示新值,### WHERE @1=99表示旧值条件 - 如果表有主键或唯一索引,WHERE 条件通常能准确定位;如果没有,可能只靠全字段匹配,这时
### WHERE行会很长 - 遇到
ENUM或SET字段,mysqlbinlog显示的是数字序号(如@3=2),不是字符串,得查表定义才能知道对应值
想真正提取可执行 SQL?别依赖 mysqlbinlog 原生输出
mysqlbinlog 的 -v 模式只是辅助分析,不是 SQL 生成器。真要还原成 INSERT/UPDATE/DELETE 语句并确保可执行,得靠第三方工具或自己写解析逻辑。
-
binlog-parser(Python)、go-mysql(Go)这类库能准确解析 ROW 事件,映射回表结构,生成带引号、转义的 SQL - 如果只有单个 binlog 文件且改动不多,手动对照
###行 + 表结构拼 SQL 更快,但别跳过字符串转义(比如'要写成'',n要保留) - 注意字符集:binlog 里存的是字节流,
mysqlbinlog默认按latin1解码,中文可能变乱码,加--character-sets-dir或提前设好客户端字符集 - 时间戳字段(
TIMESTAMP、DATETIME)在 ROW 事件里是 int 类型秒数或微秒数,mysqlbinlog -v会转成可读格式,但生成 SQL 时得确认是否要保留原值还是用NOW()
ROW 格式 binlog 本质是数据变更快照,不是操作日志。想“提取 SQL”,其实是做一次反向建模——你得清楚表结构、约束、字符集,工具只是帮你把二进制翻译成带标记的文本而已。