在一次初始化Mysql数据库,备份一张表时竟然没有成功,记录一下
1、错误信息
2、错误原因
后面查询了Mysql版本是5.6,查询了很多资料;因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 表名 as select 的方式会拆分成两部分。
create table pfdb.t_soncompany_bak20210114 like pfdb.t_soncompany;
INSERT INTO pfdb.t_soncompany_bak20210114 SELECT * FROM pfdb.t_soncompany;