


Transaktions-Commit oder Rollback in Datenbank/SQL erkennen
Im Datenbank-/SQL-Paket mit seiner Treiberschnittstelle und dem Tx-Typ ist dies nicht der Fall Es ist explizit möglich, festzustellen, ob eine Transaktion festgeschrieben oder zurückgesetzt wurde, ohne dass eine weitere Transaktion versucht werden muss. Der vom nachfolgenden Versuch zurückgegebene Fehler kann dann untersucht werden, um auf den Status der Transaktion zu schließen.
Um zusätzlichen Overhead zu vermeiden, könnte man erwägen, die Tx-Variable nach einem Commit oder Rollback auf Null zu setzen. Von diesem Ansatz wird jedoch im Allgemeinen abgeraten, da er zu unerwartetem Verhalten und Speicherverlusten führen kann.
Eine empfohlene Lösung besteht darin, einen Transaktionshandler zu verwenden, um die Transaktionslogik zu umgehen. Dadurch wird sichergestellt, dass Begin()-, Commit()- und Rollback()-Aufrufe immer innerhalb derselben Funktion erfolgen, was die Nachverfolgung vereinfacht und eine ordnungsgemäße Transaktionsabwicklung mithilfe von Defer-Anweisungen gewährleistet.
Zum Beispiel:
func Transact(db *sql.DB, txFunc func(*sql.Tx) error) (err error) { tx, err := db.Begin() if err != nil { return } defer func() { if p := recover(); p != nil { tx.Rollback() panic(p) // re-throw panic after Rollback } else if err != nil { tx.Rollback() // err is non-nil; don't change it } else { err = tx.Commit() // err is nil; if Commit returns error update err } }() err = txFunc(tx) return err }
Mit diesem Handler kann die Transaktionslogik wie folgt gekapselt werden:
func (s Service) DoSomething() error { return Transact(s.db, func (tx *sql.Tx) error { if _, err := tx.Exec(...); err != nil { return err } if _, err := tx.Exec(...); err != nil { return err } return nil }) }
Dieser Ansatz hält den Transaktionscode prägnant und gewährleistet eine konsistente Handhabung. Beachten Sie, dass der Transaktionshandler „recover()“ verwendet, um Paniken abzufangen und umgehend einen Rollback einleitet. Es sollte jedoch betont werden, dass das Zurückgeben von Fehlern der Panik vorzuziehen ist.
Das obige ist der detaillierte Inhalt vonWie kann ich das Festschreiben oder Zurücksetzen von Datenbanktransaktionen im Paket „database/sql' von Go zuverlässig erkennen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Zu den Kernmerkmalen von GO gehören die Müllsammlung, statische Verknüpfung und Unterstützung der Parallelität. 1. Das Parallelitätsmodell von GO -Sprache realisiert eine effiziente gleichzeitige Programmierung durch Goroutine und Kanal. 2. Schnittstellen und Polymorphismen werden durch Schnittstellenmethoden implementiert, so dass verschiedene Typen einheitlich verarbeitet werden können. 3. Die grundlegende Verwendung zeigt die Effizienz der Funktionsdefinition und des Aufrufs. 4. In der fortgeschrittenen Verwendung bieten Scheiben leistungsstarke Funktionen der dynamischen Größenänderung. 5. Häufige Fehler wie Rassenbedingungen können durch Getest-Race erkannt und gelöst werden. 6. Leistungsoptimierung wiederverwenden Objekte durch Sync.Pool, um den Druck der Müllabfuhr zu verringern.

Go Language funktioniert gut beim Aufbau effizienter und skalierbarer Systeme. Zu den Vorteilen gehören: 1. hohe Leistung: Kompiliert in den Maschinencode, schnelle Laufgeschwindigkeit; 2. gleichzeitige Programmierung: Vereinfachen Sie Multitasking durch Goroutinen und Kanäle; 3. Einfachheit: präzise Syntax, Reduzierung der Lern- und Wartungskosten; 4. plattform: Unterstützt die plattformübergreifende Kompilierung, einfache Bereitstellung.

Verwirrt über die Sortierung von SQL -Abfragenergebnissen. Während des Lernens von SQL stoßen Sie häufig auf einige verwirrende Probleme. Vor kurzem liest der Autor "Mick-SQL Basics" ...

Die Beziehung zwischen Technologiestapelkonvergenz und Technologieauswahl in der Softwareentwicklung, der Auswahl und dem Management von Technologiestapeln ist ein sehr kritisches Problem. In letzter Zeit haben einige Leser vorgeschlagen ...

Golang ...

Wie man drei Strukturen in der GO -Sprache vergleicht und umgeht. Bei der Go -Programmierung ist es manchmal notwendig, die Unterschiede zwischen zwei Strukturen zu vergleichen und diese Unterschiede auf die ...

Wie kann ich weltweit installierte Pakete in GO betrachten? Bei der Entwicklung mit GO -Sprache verwendet GO oft ...

Was soll ich tun, wenn die benutzerdefinierten Strukturbezeichnungen in Goland nicht angezeigt werden? Bei der Verwendung von Goland für GO -Sprachentwicklung begegnen viele Entwickler benutzerdefinierte Struktur -Tags ...


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

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Dreamweaver Mac
Visuelle Webentwicklungstools

EditPlus chinesische Crack-Version
Geringe Größe, Syntaxhervorhebung, unterstützt keine Code-Eingabeaufforderungsfunktion

WebStorm-Mac-Version
Nützliche JavaScript-Entwicklungstools

SAP NetWeaver Server-Adapter für Eclipse
Integrieren Sie Eclipse mit dem SAP NetWeaver-Anwendungsserver.

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)