Mysql备份表报错 CREATE TABLE ... SELECT is forbidden when @@GLOBAL.ENFORCE_GTID_CONSISTENCY = 1.

在Mysql 5.6版本中,由于enforce_gtid_consistency选项开启,导致使用createtable…select方式备份表时遇到错误。官方解释启用此选项后,某些SQL语句无法执行。解决方法包括临时关闭该选项或采用创建空表然后插入数据的分步操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在一次初始化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;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值