阿里云RDS调用存储过程报错ERR1449

本文探讨了在阿里云RDS MySQL 5.6环境中,应用程序调用存储过程时遇到的ERR1449错误。该错误与GTID参数enforce_gtid_consistency设置有关,当其在生产库中设为ON时,会限制特定类型SQL语句的执行。文章提供了详细的解决方案。

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

阿里云1000元通用代金券点此领取

数据库使用的是阿里云RDSmysql5.6
应用程序CALL生产库的存储过程,navicat报错ERR1449
这里写图片描述
但是在测试库使用时并没有问题。
以为是权限问题,检查后发现和测试库的权限是一样的。

查看应用后台日志发现ERROR如下
这里写图片描述
看内容是关于GTID参数设置的问题,发现确实日志中提示的enforce_gtid_consistency参数在生产库中是ON,测试库中是OFF,并且MySQL5.6默认是开启的
这个参数是ON表示启动GTID模式,MySQL官方文档里说明启用enforce_gtid_consistency时,MySQL只允许能够保障事务安全,并且能够被日志记录的SQL语句被执行,像create table … select 和 create temporary table语句,以及同时更新事务表和非事务表的SQL语句或事务都不允许执行。
不能在事务内执行,但可以在事务外执行,但必须设置set autocommit = 1 ,阿里云手册里也有介绍
这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值