解决报错:Error Code: 1786 Statement violates GTID consistency: CREATE TABLE ... SELECT.

1、错误描述

1 queries executed, 0 success, 1 errors, 0 warnings

查询:call account_check_main('20180511')

错误代码: 1786
Statement violates GTID consistency: CREATE TABLE ... SELECT.

执行耗时   : 0 sec
传送时间   : 0 sec
总耗时      : 0.066 sec
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

2、错误原因

这是因为在5.6及以上的版本内,开启了 enforce_gtid_consistency=true 功能导致的,MySQL官方解释说当启用 enforce_gtid_consistency 功能的时候,MySQL只允许能够保障事务安全,并且能够被日志记录的SQL语句被执行,像create table … select 和 create temporarytable语句,以及同时更新事务表和非事务表的SQL语句或事务都不允许执行。

3、解决方法

方法一(推荐):

修改 :SET @@GLOBAL.ENFORCE_GTID_CONSISTENCY = off;

配置文件中 :ENFORCE_GTID_CONSISTENCY = off;

方法二:

create table xxx as select 的方式会拆分成两部分。

create table xxxx like data_mgr;
insert into xxxx select *from data_mgr;

1、错误描述

1 queries executed, 0 success, 1 errors, 0 warnings

查询:call account_check_main('20180511')

错误代码: 1786
Statement violates GTID consistency: CREATE TABLE ... SELECT.

执行耗时   : 0 sec
传送时间   : 0 sec
总耗时      : 0.066 sec
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

2、错误原因

这是因为在5.6及以上的版本内,开启了 enforce_gtid_consistency=true 功能导致的,MySQL官方解释说当启用 enforce_gtid_consistency 功能的时候,MySQL只允许能够保障事务安全,并且能够被日志记录的SQL语句被执行,像create table … select 和 create temporarytable语句,以及同时更新事务表和非事务表的SQL语句或事务都不允许执行。

3、解决方法

方法一(推荐):

修改 :SET @@GLOBAL.ENFORCE_GTID_CONSISTENCY = off;

配置文件中 :ENFORCE_GTID_CONSISTENCY = off;

方法二:

create table xxx as select 的方式会拆分成两部分。

create table xxxx like data_mgr;
insert into xxxx select *from data_mgr;

猜你喜欢

转载自blog.csdn.net/tengxing007/article/details/80942951