


Wie führt man mit Go effizient Massenaktualisierungen in PostgreSQL durch?
Dec 05, 2024 am 07:19 AMMassenaktualisierung in PostgreSQL mit Go Query Builder
Wenn mehrere Zeilen in einer PostgreSQL-Datenbank aktualisiert werden müssen, besteht der traditionelle Ansatz darin, eine separate UPDATE-Anweisung dafür auszuführen jede Zeile. Aus Leistungsgründen ist es jedoch häufig wünschenswert, eine einzelne UPDATE-Anweisung auszuführen, um mehrere Zeilen auf einmal zu aktualisieren.
Abgeleiteter Tabellenansatz
Eine effektive Methode zur Massenaktualisierung in PostgreSQL ist die Verwendung eine abgeleitete Tabelle. Bei dieser Technik wird eine temporäre Tabelle mit den gewünschten Aktualisierungen erstellt und dann die Daten in dieser Tabelle verwendet, um die Zieltabelle zu aktualisieren.
Stellen Sie sich das folgende Szenario vor, in dem wir mehrere Zeilen in der Tabelle „Tabelle“ mit neuen aktualisieren möchten Werte für die Spalten „column_a“ und „column_b“:
import ( "database/sql" _"github.com/jackc/pgx/v4/stdlib" // PostgreSQL driver ) func main() { db, err := sql.Open("pgx", "host=localhost port=5432 dbname=test user=postgres password=mysecretpassword") if err != nil { panic(err) } defer db.Close() // Prepare the derived table with updated values query := `UPDATE t SET column_a = v.column_a, column_b = v.column_b FROM (VALUES (1, 'FINISH', 1234), (2, 'UNFINISH', 3124) ) v(id, column_a, column_b) WHERE v.id = t.id;` _, err = db.Exec(query) if err != nil { panic(err) } // Optionally, you can verify the updated rows rows, err := db.Query("SELECT * FROM table WHERE id IN (1, 2)") if err != nil { panic(err) } defer rows.Close() for rows.Next() { var id int var columnA, columnB string if err := rows.Scan(&id, &columnA, &columnB); err != nil { panic(err) } fmt.Printf("ID: %d, Column A: %s, Column B: %s\n", id, columnA, columnB) } }
Dieser Ansatz bietet Flexibilität beim Hinzufügen oder Entfernen von Zeilen und Spalten in der abgeleiteten Tabelle, ohne die Hauptabfrage zu ändern. Es hilft auch, versehentliche Fehler im Vergleich zur expliziten Angabe mehrerer UPDATE-Anweisungen zu vermeiden.
Das obige ist der detaillierte Inhalt vonWie führt man mit Go effizient Massenaktualisierungen in PostgreSQL durch?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heißer Artikel

Hot-Tools-Tags

Heißer Artikel

Heiße Artikel -Tags

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 schreibe ich Scheinobjekte und Stubs zum Testen in Go?

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

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 Dateien in Go Language bequem?

Wie kann ich Linter und statische Analyse -Tools verwenden, um die Qualität und Wartbarkeit meines GO -Codes zu verbessern?
