Statement violates GTID consistency: CREATE TABLE ... SELECT.

1、情况描述

在执行sql:create table table_a_copy  as select * from table_a 时,发现sql执行后,并未生成新的表,而是提示Statement violates GTID consistency: CREATE TABLE ... SELECT.

2、问题分析

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

3、解决方法  


方法一(推荐):说明:GTID( Global Transaction Identifier)全局事务标识
修改 :SET @@GLOBAL.ENFORCE_GTID_CONSISTENCY = off;

配置文件中 :ENFORCE_GTID_CONSISTENCY = off;

方法二:
create table 表A as select 表B 的方式会拆分成两部分。

create table 表A like 表B ;
insert into 表A select *from 表B ;

我才用的是第二种方法。如下图

可以正常复制成功

参考:https://blog.csdn.net/loveshunyi/article/details/90209333 

猜你喜欢

转载自blog.csdn.net/weixin_40873693/article/details/119684273