mysql binlog mixed_MySQL记录binlog的三种模式row/statement/mixed

row模式

行模式。对于ddl,会把每一条记录的变更记录下来。dml会记录执行的sql语句。

现在有一些业务需要获取数据的变更change feed capture,就需要使用row模式。

statement模式

语句模式。不管是ddl还是dml,记录的都是sql语句,被记录下来的同时还有一些上下文信息。当执行sql语句的时候,由于每台机器的环境不一样,容易出现数据不致的问题,执行结果不可控。

mixed

混合模式。会根据具体的SQL语句选择使用row和还是statement。update table_name set name="Jhon" where user_id=1;

这条语句起作用的只有一条记录,使用row模式。update table_name set name="Jhon";

这条语句执行的记录条数不确定,使用statement模式。

但是当binlog因为一些原因要回放执行的时候会出问题,它会把后来新加入的记录也都给修改了。所以存在风险,需要谨慎使用。

综上,最安全最简单的模式是row模式。缺点是数据量大的时候,会产生很多日志,占用大量磁盘空间。

可以在运行时修改复制模式mysql> SET SESSION binlog_format = 'ROW';

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值