0

0

mysql5.6+ myisam 表无法在事务中处理,会报错。如何解决

php中文网

php中文网

发布时间:2016-06-06 20:41:01

|

1315人浏览过

|

来源于php中文网

原创

我觉得我已经说的很清楚了,不好好看原文的、语文是计算机老师教的那些回复者,我也真的没法逐个回复了。 我当然知道 myisam 类型表不支持事务,我就是要用这一点实现事务中的表日志!请再仔细看题!!!

mysql 5.6 以后,在事务过程中,无法再操作 myisam 类型的表。
如果操作会报以下错误:

General error: 1785 When @@GLOBAL.ENFORCE_GTID_CONSISTENCY = 1, updates to non-transactional tables can only be done in either autocommitted statements or single-statement transactions, and never in the same statement as updates to transactional tables.

因为业务逻辑需要,现在必须在一个大事务中,保存一些原始数据。并且如果事务rollback,这些数据仍需保存下来。所以之前用 myisam 类型表都是可以实现的,现在果断的报错了。

存缓存最后commit后保存的方案我已经考虑过了... 要涉及的改动太多
只是想问问大家有没有什么更好的方案...

重新说明一下:我的意思就是之前借助于myisam不支持事务的特性,可以保存事务中的数据,且不用担心事务rollback后这部分数据也无法保存下来的问题,而新版本的mysql已经无法这样操作,会异常

回复内容:

我觉得我已经说的很清楚了,不好好看原文的、语文是计算机老师教的那些回复者,我也真的没法逐个回复了。 我当然知道 myisam 类型表不支持事务,我就是要用这一点实现事务中的表日志!请再仔细看题!!!

mysql 5.6 以后,在事务过程中,无法再操作 myisam 类型的表。
如果操作会报以下错误:

General error: 1785 When @@GLOBAL.ENFORCE_GTID_CONSISTENCY = 1, updates to non-transactional tables can only be done in either autocommitted statements or single-statement transactions, and never in the same statement as updates to transactional tables.

因为业务逻辑需要,现在必须在一个大事务中,保存一些原始数据。并且如果事务rollback,这些数据仍需保存下来。所以之前用 myisam 类型表都是可以实现的,现在果断的报错了。

存缓存最后commit后保存的方案我已经考虑过了... 要涉及的改动太多
只是想问问大家有没有什么更好的方案...

重新说明一下:我的意思就是之前借助于myisam不支持事务的特性,可以保存事务中的数据,且不用担心事务rollback后这部分数据也无法保存下来的问题,而新版本的mysql已经无法这样操作,会异常

从报错信息看,mysql中的参数@@GLOBAL.ENFORCE_GTID_CONSISTENCY = 1 所以无法在事务中使用myisam,事务是mysql的事,跟php没有关系啊!

不知道是不是我才疏学浅 - -#
两位回答的咋都在讨论执行参数的事,可是myisam根本就不支持事物啊。

mysql只有innodb表才支持事务吧。

Visily
Visily

适合每个人的UI设计工具,支持草图转原型图、截图转线框图以及文生图

下载

innodb才能支持事物操作,楼主的数据库比我还菜!!!

我之前升级mysql数据库从5.5升级到5.6的时候碰到过这样的报错 是因为关联数据库表使用了事务 但是有极个别关联表用的是myisam 把myiasm改成innnodb引擎就可以了

写事务功能起码要先了解下事务吧,innodb支持,myisam不支持。

相关专题

更多
PHP 表单处理与文件上传安全实战
PHP 表单处理与文件上传安全实战

本专题聚焦 PHP 在表单处理与文件上传场景中的实战与安全问题,系统讲解表单数据获取与校验、XSS 与 CSRF 防护、文件类型与大小限制、上传目录安全配置、恶意文件识别以及常见安全漏洞的防范策略。通过贴近真实业务的案例,帮助学习者掌握 安全、规范地处理用户输入与文件上传的完整开发流程。

1

2026.01.13

PPT交互图表教程大全
PPT交互图表教程大全

本专题整合了PPT交互图表相关教程汇总,阅读专题下面的文章了解更多详细内容。

41

2026.01.12

Java 项目构建与依赖管理(Maven / Gradle)
Java 项目构建与依赖管理(Maven / Gradle)

本专题系统讲解 Java 项目构建与依赖管理的完整体系,重点覆盖 Maven 与 Gradle 的核心概念、项目生命周期、依赖冲突解决、多模块项目管理、构建加速与版本发布规范。通过真实项目结构示例,帮助学习者掌握 从零搭建、维护到发布 Java 工程的标准化流程,提升在实际团队开发中的工程能力与协作效率。

19

2026.01.12

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

134

2026.01.09

c++框架学习教程汇总
c++框架学习教程汇总

本专题整合了c++框架学习教程汇总,阅读专题下面的文章了解更多详细内容。

66

2026.01.09

学python好用的网站推荐
学python好用的网站推荐

本专题整合了python学习教程汇总,阅读专题下面的文章了解更多详细内容。

139

2026.01.09

学python网站汇总
学python网站汇总

本专题整合了学python网站汇总,阅读专题下面的文章了解更多详细内容。

13

2026.01.09

python学习网站
python学习网站

本专题整合了python学习相关推荐汇总,阅读专题下面的文章了解更多详细内容。

19

2026.01.09

俄罗斯手机浏览器地址汇总
俄罗斯手机浏览器地址汇总

汇总俄罗斯Yandex手机浏览器官方网址入口,涵盖国际版与俄语版,适配移动端访问,一键直达搜索、地图、新闻等核心服务。

105

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8.5万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 6.9万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号