查询数据,并将查询出来的数据放到新的备份表。使用以下语句:
--导入数据并生成表
select * into 表 from tablename
执行失败,返回:
SQL 错误 [1786] [HY000]: Statement violates GTID consistency: CREATE TABLE … SELECT.
错误原因
这是因为在5.6及以上的版本内,开启了 enforce_gtid_consistency=true
功能导致的,MySQL官方解释说当启用 enforce_gtid_consistency
功能的时候,MySQL只允许能够保障事务安全,并且能够被日志记录的SQL语句被执行,像create table … select 和 create temporarytable语句,以及同时更新事务表和非事务表的SQL语句或事务都不允许执行。
解决方法
方法一(推荐):
修改 :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;
参考: https://blog.csdn.net/tengxing007/article/details/80942951