1 日志分为三种格式
statement 基于语句的
row 基于行的
mixed 复合的
区别:
基于语句的 简单,精悍,服务器会将数据修改事件以SQL语句的形式写入二进制,内容比较容易理解
语句行的 对要修改哪些数据 提供了跟精细的控制,但是不容易理解,出现这种格式的原因在于,有些语句可能不够明确,在主服务器和从服务器上执行可能会出现不同的效果
基于mixed 服务器会根据最适当的时候切换使用基于语句或者基于行的格式
2 如何查看当前系统的格式
mysql> show global variables like ‘%format%‘;
3 如何修改
暂时修改 当前会话或别的会话
mysql> set session binlog_format=‘mixed‘;
mysql> set global binlog_format=‘mixed‘;
重启mysqld 就不生效了
永久生效
写入my.cnf 的配置文件当中
binlog_format=
4 演示的不同格式效果
[[email protected] logs]# mysqlbinlog master_bin.000003 和 不断set 修改 format_log
mysql> show binlog events in ‘master_bin.000003‘; 简便的查看每个pos期间执行的操作内容
基于statement 语句的
# at 781
#141116 22:40:42 server id 100 end_log_pos 897 CRC32 0x63842d06 Query thread_id=3 exec_time=0 error_code=0
SET TIMESTAMP=1416148842/*!*/;
insert student (id,name) values (1,‘andy‘)
/*!*/;
| master_bin.000003 | 781 | Query | 100 | 897 | use `mydb`; insert student (id,name) values (1,‘andy‘)
基于row的
# at 1254
#141116 22:43:38 server id 100 end_log_pos 1303 CRC32 0x115dc0d4 Write_rows: table id 70 flags: STMT_END_F
BINLOG ‘
GrhoVBNkAAAANQAAAOYEAAAAAEYAAAAAAAEABG15ZGIAB3N0dWRlbnQAAgP+Av4UA9TLV8c=
GrhoVB5kAAAAMQAAABcFAAAAAEYAAAAAAAEAAgAC//wCAAAACGN1aWRlaHVh1MBdEQ==
其实这条执行的操作也是一个insert 语句但是 我们无法阅读
| master_bin.000003 | 1254 | Write_rows | 100 | 1303 | table_id: 70 flags: STMT_END_F
基于mixed的 这里它自动选择了合适的 statement 基于语句的
| master_bin.000003 | 1492 | Query | 100 | 1615 | use `mydb`; insert student (id,name) values (4,‘zhangxueyou‘)