mysql5.6+ myisam 表无法在事务中处理,会报错。如何解决
我觉得我已经说的很清楚了,不好好看原文的、语文是计算机老师教的那些回复者,我也真的没法逐个回复了。 我当然知道 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表才支持事务吧。
innodb才能支持事物操作,楼主的数据库比我还菜!!!
我之前升级mysql数据库从5.5升级到5.6的时候碰到过这样的报错 是因为关联数据库表使用了事务 但是有极个别关联表用的是myisam 把myiasm改成innnodb引擎就可以了
写事务功能起码要先了解下事务吧,innodb支持,myisam不支持。

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

PHP und Python haben jeweils ihre eigenen Vorteile und wählen nach den Projektanforderungen. 1.PHP ist für die Webentwicklung geeignet, insbesondere für die schnelle Entwicklung und Wartung von Websites. 2. Python eignet sich für Datenwissenschaft, maschinelles Lernen und künstliche Intelligenz mit prägnanter Syntax und für Anfänger.

PHP ist immer noch dynamisch und nimmt immer noch eine wichtige Position im Bereich der modernen Programmierung ein. 1) Einfachheit und leistungsstarke Unterstützung von PHP machen es in der Webentwicklung weit verbreitet. 2) Seine Flexibilität und Stabilität machen es ausstehend bei der Behandlung von Webformularen, Datenbankoperationen und Dateiverarbeitung; 3) PHP entwickelt sich ständig weiter und optimiert, geeignet für Anfänger und erfahrene Entwickler.

PHP wird verwendet, um dynamische Websites zu erstellen. Zu den Kernfunktionen gehören: 1. Dynamische Inhalte generieren und Webseiten in Echtzeit generieren, indem Sie eine Verbindung mit der Datenbank herstellen; 2. Verarbeiten Sie Benutzerinteraktions- und Formulareinreichungen, überprüfen Sie Eingaben und reagieren Sie auf Operationen. 3. Verwalten Sie Sitzungen und Benutzerauthentifizierung, um eine personalisierte Erfahrung zu bieten. 4. Optimieren Sie die Leistung und befolgen Sie die Best Practices, um die Effizienz und Sicherheit der Website zu verbessern.

PHP wird in E-Commerce, Content Management Systems und API-Entwicklung häufig verwendet. 1) E-Commerce: Wird für die Einkaufswagenfunktion und Zahlungsabwicklung verwendet. 2) Content -Management -System: Wird für die Erzeugung der dynamischen Inhalte und die Benutzerverwaltung verwendet. 3) API -Entwicklung: Wird für die erholsame API -Entwicklung und die API -Sicherheit verwendet. Durch Leistungsoptimierung und Best Practices werden die Effizienz und Wartbarkeit von PHP -Anwendungen verbessert.

PHP und Python haben ihre eigenen Vor- und Nachteile, und die Wahl hängt von den Projektbedürfnissen und persönlichen Vorlieben ab. 1.PHP eignet sich für eine schnelle Entwicklung und Wartung großer Webanwendungen. 2. Python dominiert das Gebiet der Datenwissenschaft und des maschinellen Lernens.

PHP ist hauptsächlich prozedurale Programmierung, unterstützt aber auch die objektorientierte Programmierung (OOP). Python unterstützt eine Vielzahl von Paradigmen, einschließlich OOP, funktionaler und prozeduraler Programmierung. PHP ist für die Webentwicklung geeignet, und Python eignet sich für eine Vielzahl von Anwendungen wie Datenanalyse und maschinelles Lernen.

PHP verwendet MySQLI- und PDO-Erweiterungen, um in Datenbankvorgängen und serverseitiger Logikverarbeitung zu interagieren und die serverseitige Logik durch Funktionen wie Sitzungsverwaltung zu verarbeiten. 1) Verwenden Sie MySQLI oder PDO, um eine Verbindung zur Datenbank herzustellen und SQL -Abfragen auszuführen. 2) Behandeln Sie HTTP -Anforderungen und Benutzerstatus über Sitzungsverwaltung und andere Funktionen. 3) Verwenden Sie Transaktionen, um die Atomizität von Datenbankvorgängen sicherzustellen. 4) Verhindern Sie die SQL -Injektion, verwenden Sie Ausnahmebehandlung und Schließen von Verbindungen zum Debuggen. 5) Optimieren Sie die Leistung durch Indexierung und Cache, schreiben Sie hochlesbarer Code und führen Sie die Fehlerbehandlung durch.

Der Prozess des Startens von MySQL in Docker besteht aus den folgenden Schritten: Ziehen Sie das MySQL -Image zum Erstellen und Starten des Containers an, setzen
