Error Code: 1786 Statement violates GTID consistency: CREATE TABLE ... SELECT.
Posted eikixu
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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
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;
以上是关于Error Code: 1786 Statement violates GTID consistency: CREATE TABLE ... SELECT.的主要内容,如果未能解决你的问题,请参考以下文章