MySQL错误提示mysql Statement violates GTID consistency
MySQL版本用的是5.7,MySQL的GTID指的是全局事务ID(global transaction identifier)
1、错误描述
执行CREATE TABLE tig_pairs_20190521 AS SELECT *FROM tig_pairs报错:
错误代码: 1786
Statement violates GTID consistency: CREATE TABLE ... SELECT.
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;
方法三(推荐)
使用临时表的方式先创建表,然后再insert 数据
创建临时表:
CREATE TEMPORARY TABLE select id from test;查看临时表表结构
show create table Sale;CREATE TEMPORARY TABLE `sale` (`id` int(11) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;通过临时表创建表结构
create table xxxx like Sale;insert 数据
insert into xxx select id from test;
