Chinaunix首页 | 论坛 | 博客
  • 博客访问: 344987
  • 博文数量: 87
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 727
  • 用 户 组: 普通用户
  • 注册时间: 2014-11-27 15:56
个人简介

开心了, 就笑;不开心了,就过会儿再笑。。。。

文章分类

全部博文(87)

文章存档

2017年(16)

2016年(28)

2015年(33)

2014年(10)

我的朋友

分类: Mysql/postgreSQL

2016-03-02 14:00:20

有很多时候,我们会希望一条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数据库数据不一致,要谨慎操作。
在数据库执行操作时,一定要保持头脑清醒,一定要非常清楚自己在做什么。
阅读(2490) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~