mysql 复制过滤重复如何解决
2012-11-26 00:00
627 查看
1、replicate_do_db 和 replicate_ignore_db 不要同时出现。容易出现混淆。也是毫无意义的。
Replicate_Do_DB: db1
Replicate_Ignore_DB: db2
statement模式:
使用use 语句
use db1;insert into tb1 values (1);
use db2;insert into tb2 values (2);
以上在slave上均能正确复制,tb1 有数据,tb2没有数据。
不使用use 语句
insert into db1.tb1 values (11);
insert into db2.tb2 values (11);
结果tb1没有数据,tb2也没有数据(按照文档上来讲,应该有的)
row模式:
无论是否使用use 语句,均能正确复制
小结:对于statement模式,SQL语句必须使用use 语句,并设置设置多个replicate_do_db来复制多个DB。
2、只进行表级别过滤的时候,对于statement模式,无论是否使用use语句,均能正确复制。row模式也是可以的。(表名它匹配的表的全名:数据库名+表名)
replicate_do_table=db1.tb1
statement模式:
use db1; insert into tb1 values (22);
insert into db1.tb1 values (22);
两者的复制结果一致。
(同样do 和 ignore 不要混用,除非出现过滤DB的情况)
3、有DB过滤规则的时候,statment模式必须使用USE语句,不能出现 db.表名,db.视图,db.存储程序这样的形式。row模式完胜!
replicate-ignore-db = db1
replicate-do-table = db2.tbl2
USE db1;
INSERT INTO db2.tbl2 VALUES (1);
row模式下,
默认DB不是db1,所以跳过第一条规则,执行表的规则,行被插入
statement模式下,
insert 语句被忽略,表的过滤规则已经在DB级别停止,所以没有做检查。
Replicate_Do_DB: db1
Replicate_Ignore_DB: db2
statement模式:
使用use 语句
use db1;insert into tb1 values (1);
use db2;insert into tb2 values (2);
以上在slave上均能正确复制,tb1 有数据,tb2没有数据。
不使用use 语句
insert into db1.tb1 values (11);
insert into db2.tb2 values (11);
结果tb1没有数据,tb2也没有数据(按照文档上来讲,应该有的)
row模式:
无论是否使用use 语句,均能正确复制
小结:对于statement模式,SQL语句必须使用use 语句,并设置设置多个replicate_do_db来复制多个DB。
2、只进行表级别过滤的时候,对于statement模式,无论是否使用use语句,均能正确复制。row模式也是可以的。(表名它匹配的表的全名:数据库名+表名)
replicate_do_table=db1.tb1
statement模式:
use db1; insert into tb1 values (22);
insert into db1.tb1 values (22);
两者的复制结果一致。
(同样do 和 ignore 不要混用,除非出现过滤DB的情况)
3、有DB过滤规则的时候,statment模式必须使用USE语句,不能出现 db.表名,db.视图,db.存储程序这样的形式。row模式完胜!
replicate-ignore-db = db1
replicate-do-table = db2.tbl2
USE db1;
INSERT INTO db2.tbl2 VALUES (1);
row模式下,
默认DB不是db1,所以跳过第一条规则,执行表的规则,行被插入
statement模式下,
insert 语句被忽略,表的过滤规则已经在DB级别停止,所以没有做检查。
相关文章推荐
- mysql 复制过滤重复如何解决
- 解决sql 过滤重复数据记录的方法(Oracle)
- MySQL复制,replicate-ignore-db模式下 如何正常同步
- [MySQL] 同步一张表、复制过滤设置
- MySQL5.6 GTID模式,同步复制报错不能跳过解决方法
- MySQL的主从复制步骤详解及常见错误解决方法
- 如何解决mysql的Table is read only错误
- MySql-如何查询删除数据表重复记录
- MYSQL与Oracle如何处理重复数据的SQL
- 如何解决mysql安装过程中,第三步和第四步
- 如何解决将比较大的数据库备份文件导入到Mysql中
- 如何解决MySQL 5.7 Access denied for user 'root'@'localhost' (using password YES)问题?
- 在mac下安装mysql时 Access denied for user 'root'@'localhost' (using password: YES) 如何解决
- 如何解决使用远程工具登陆mysql,缺乏权限的问题
- mysql并发插入重复数据问题的解决思路
- MySQL主键唯一键重复插入解决方法
- 如何解决本地电脑不能复制文件到远程服务器的方法
- mysql如何新创建一个mysql只复制结构,或复制自己想要的内容
- java使用mysql和redis如何解决“商品超卖”
- 如何解决Cloud9在vim模式下整行复制的时候自动换行的问题