这是因为在5.6及以上的版本内,开启了 enforce_gtid_consistency=true 功能导致的,MySQL官方解释说当启用 enforce_gtid_consistency 功能的时候,MySQL只允许能够保障事务安全,并且能够被日志记录的SQL语句被执行,像create table … select 和 create temporarytable语句,以及同时更新事务表和非事务表的SQL语句或事务都不允许执行。
-
方法一:
SET @gsql=concat('create table ',TBL_END_NAME,' as select * from TEMP_SE_ZH_DEPT_PERIOD_RESULT');
改为:
SET @gsql=concat('create table ',TBL_END_NAME,' like TEMP_SE_ZH_DEPT_PERIOD_RESULT');
或者:
create table xxx as select
的方式会拆分成两部分。create table xxxx like data_mgr; insert into xxxx select *from data_mgr;
-
方法二:修改 :
SET @@GLOBAL.ENFORCE_GTID_CONSISTENCY = off;
配置文件中 :ENFORCE_GTID_CONSISTENCY = off;