


Wie funktioniert die Upsert-Funktion von GORM im Vergleich zu FirstOrCreate und FirstOrInit?
Upsert: Erstellen oder Aktualisieren in GORM
In GORM können sowohl die FirstOrCreate- als auch die FirstOrInit-Methode zum Abrufen oder Erstellen eines Datenbankeintrags verwendet werden. Allerdings kann unklar sein, ob ein Datensatz neu erstellt oder aktualisiert wurde.
Upsert-Lösung mit Upsert-On-Conflict
Ab GORM 1.20.x eine verbesserte Die Upsert-Funktion wird eingeführt, die Konfliktbehandlungsfunktionen für verschiedene Datenbanken nutzt.
// Update columns when conflict on id DB.Clauses(clause.OnConflict{ Columns: []clause.Column{{Name: "id"}}, DoUpdates: clause.AssignmentColumns([]string{"name", "age"}), }).Create(&users)
Dieses Snippet übersetzt sich in SQL-Anweisungen wie:
- SQL Server: MERGE INTO „users“ USING *** WHEN NOT MATCHED THEN INSERT *** WHEN MATCHED THEN UPDATE SET „name“ ="excluded"."name";
- PostgreSQL: INSERT INTO "users" *** ON CONFLICT ("id") DO UPDATE SET "name"="excluded"."name", "age"="excluded"."age";
- MySQL : INSERT INTO 'users' *** ON DUPLICATE KEY UPDATE 'name'=VALUES(name),'age=VALUES(age);
Fallback-Lösung für ältere GORM-Versionen
Für GORM-Versionen vor 1.9 .x besteht ein effizienterer Ansatz darin, zuerst eine Aktualisierung zu versuchen und anschließend einen neuen Datensatz zu erstellen, wenn keine Übereinstimmung vorliegt gefunden.
// Update only set name=nick if err := db.Model(&newUser).Where("id = ?", 3333).Update("name", "nick").Error; err != nil { // Handle error... if gorm.IsRecordNotFoundError(err) { db.Create(&newUser) // Create new record from newUser } }
Unterscheidung zwischen FirstOrInit und FirstOrCreate
Während beide Methoden einem ähnlichen Zweck dienen, ist ihr Verhalten unterschiedlich:
- FirstOrInit: Initialisiert eine Struktur, wenn der Datensatz nicht vorhanden ist, erstellt ihn jedoch nicht Datensatz.
- FirstOrCreate: Erstellt einen Datensatz, wenn er nicht vorhanden ist, und ruft den Datensatz in der Struktur ab.
Das obige ist der detaillierte Inhalt vonWie funktioniert die Upsert-Funktion von GORM im Vergleich zu FirstOrCreate und FirstOrInit?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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

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

GO Language Pack Import: Was ist der Unterschied zwischen Unterstrich und ohne Unterstrich?

Wie kann ich kurzfristige Informationsübertragung zwischen Seiten im BeEGO-Framework implementieren?

Wie konvertieren Sie die Liste der MySQL -Abfrageergebnisse in eine benutzerdefinierte Struktur -Slice in Go -Sprache?

Wie kann ich benutzerdefinierte Typ -Einschränkungen für Generika in Go definieren?

Wie schreibe ich Scheinobjekte und Stubs zum Testen in Go?

Wie schreibe ich Dateien in Go Language bequem?

Wie kann ich Tracing -Tools verwenden, um den Ausführungsfluss meiner GO -Anwendungen zu verstehen?
