有很多时候,我们会希望一条SQL语句只在Master数据库上执行,而不复制到Slave数据库,这时候,sql_log_bin这个参数就正是你需要的。
例如,我们希望将Master数据库库的一个数据表修改为压缩的InnoDB存储引擎,但Slave数据库保持MyISAM不变,我们就可以这样操作:
master mysql>set sql_log_bin=0;
master 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数据库数据不一致,要谨慎操作。
在数据库执行操作时,一定要保持头脑清醒,一定要非常清楚自己在做什么。
阅读(2543) | 评论(0) | 转发(0) |