备份数据库中的某个表的数据报错Statement violates GTID consistency

 

一、错误描述安全

执行CREATE TABLE tig_pairs_20190521 AS SELECT *FROM tig_pairs报错:日志

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

查询:call account_check_main('20180511')it

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

执行耗时 : 0 sec
传送时间 : 0 sec
总耗时 : 0.066 sec
1
2
3
4
5
6
7
8
9
10
二、错误缘由
这是由于在5.6及以上的版本内,开启了 enforce_gtid_consistency=true 功能致使的,MySQL官方解释说当启用 enforce_gtid_consistency 功能的时候,MySQL只容许可以保障事务安全,而且可以被日志记录的SQL语句被执行,像create table … select 和 create temporarytable语句,以及同时更新事务表和非事务表的SQL语句或事务都不容许执行。table

三、解决方法
方法一(推荐):
修改 :SET @@GLOBAL.ENFORCE_GTID_CONSISTENCY = off;class

配置文件中 :ENFORCE_GTID_CONSISTENCY = off;配置

方法二:
create table xxx as select 的方式会拆分红两部分。select

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

相关文章
相关标签/搜索