zoukankan      html  css  js  c++  java
  • MySQL关于GTID的一些功能限制

    参考文献:https://www.cnblogs.com/luckcs/articles/6295992.html

    更新非事务引擎:

    1. Case重现:
      master:对一个innodb表做一个多sql更新的事物,效果是产生一个GTID。
      slave:对应的表是MYISAM引擎,执行这个GTID的第一个语句后就会报错,因为非事务引擎一个sql就是一个事务。

    2. 错误编号:
      last_Errno:1756

    3. 异常恢复方案:
      (1)、简单的stop slave; start slave;就能够忽略错误。但是这个时候主从的一致性已经出现问题。需要手工的把slave差的数据补上。
      (2)、首先将引擎调整为一样的,slave也改为事务引擎。

    create table ....select statements

    1. case重现:
      master:直接执行一个create table select * from table;的sql

    2. 报错:
      error 1786: Statement violates GTID consistency: CREATE TABLE ... SELECT.

    3. 原理:
      由于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

    1. update t1,t2 set t1.id=1000,t2.id=1000 where t1.id=t2.id;

    2. 报错:1785

    3. 原理和第二个相同。

  • 相关阅读:
    csp-s模拟 77/78 (达哥专场)
    csp-s 模拟76
    csp-s模拟75 导弹袭击
    反思集
    模拟69/70 考试反思
    抱大腿
    csp-s模拟61 甜圈
    实时记录
    好题思路集汇
    半集训反思 8.28 「路,还是要自己走的」
  • 原文地址:https://www.cnblogs.com/jie828/p/11281142.html
Copyright © 2011-2022 走看看