参考文献:https://www.cnblogs.com/luckcs/articles/6295992.html
更新非事务引擎:
-
Case重现:
master:对一个innodb表做一个多sql更新的事物,效果是产生一个GTID。
slave:对应的表是MYISAM引擎,执行这个GTID的第一个语句后就会报错,因为非事务引擎一个sql就是一个事务。 -
错误编号:
last_Errno:1756 -
异常恢复方案:
(1)、简单的stop slave; start slave;就能够忽略错误。但是这个时候主从的一致性已经出现问题。需要手工的把slave差的数据补上。
(2)、首先将引擎调整为一样的,slave也改为事务引擎。
create table ....select statements
-
case重现:
master:直接执行一个create table select * from table;的sql -
报错:
error 1786: Statement violates GTID consistency: CREATE TABLE ... SELECT. -
原理:
由于create table ...select语句会生成两个sql,一个是DDL创建表SQL,一个是insert into 插入数据的sql。由于DDL会导致自动提交,所以这个sql至少需要两个GTID,但是GTID模式下,只能给这个sql生成一个GTID,如果强制执行会导致和上面更新非事务引擎一样的结果。
create table xxx as select 的方式会被拆分成两部分。
create table xxxx like data_mgr;
insert into xxxx select * from data_mgr;
一个sql同时操作innodb引擎和myisam引擎:
case重现:t1表是innodb,t2表是myisam
-
update t1,t2 set t1.id=1000,t2.id=1000 where t1.id=t2.id;
-
报错:1785
-
原理和第二个相同。