sql_log_bin是mysql session的一个变量,查看语句:
mysql> select @@session.sql_log_bin; +-----------------------+ | @@session.sql_log_bin | +-----------------------+ | 1 | +-----------------------+ 1 row in set (0.00 sec)
可以看出sql_log_bin的值是1|0, 当sql_log_bin的值为0的时候,本次连接mysql的session里面所输入的语句都不会被计入bin_log里面,也不会被从库执行。
有很多时候,我们会希望一条SQL语句只在Master数据库上执行,而不复制到Slave数据库,这时候,sql_log_bin这个参数就正是你需要的。
例如,我们希望将Master数据库库的一个数据表修改为压缩的InnoDB存储引擎,但Slave数据库保持MyISAM不变,我们就可以这样操作:
mysql> set sql_log_bin=0; mysql> alter table example_table engine=innodb row_format=compressed;
使用这个参数是需要注意几点:
1,千万不要不假思索的加上 global 修饰符(set global sql_log_bin=0),这样会导致所有在Master数据库上执行的语句都不记录binlog,这肯定不是你想要的结果。
2,INSERT、UPDATE、DELETE的SQL语句会导致Master和Slave数据库数据不一致,要谨慎操作。在数据库执行操作时,一定要保持头脑清醒,一定要非常清楚自己在做什么。