登录
原创

关于mysql Statement violates GTID consistency 错误

发布于 2020-12-21 阅读 1456
  • MySQL
原创

在执行如下Mysql语句时

create table 表A  as select * from 表B

会提示如下错误

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

原因

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

解决办法:
1、

SET @@GLOBAL.ENFORCE_GTID_CONSISTENCY = off;

配置文件中 :ENFORCE_GTID_CONSISTENCY = off;

2、
create table 表A as select 表B 的方式会拆分成两部分。

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

评论区

励志做一条安静的咸鱼,从此走上人生巅峰。

0

0

0

举报