• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

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

php 搞代码 4年前 (2022-01-25) 39次浏览 已收录 0个评论
文章目录[隐藏]

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

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

<code>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.</code>

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

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

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

回复内容:

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

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

<code>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.</code>

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

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

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

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

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

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

+本文来源gao!%daima.com搞$代*!码9网(

搞gaodaima代码

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

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

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


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:mysql5.6+ myisam 表无法在事务中处理,会报错。如何解决

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址