mysql 参数 sql_log_bin

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数据库数据不一致,要谨慎操作。在数据库执行操作时,一定要保持头脑清醒,一定要非常清楚自己在做什么。