


So erhalten Sie Spaltenwerte vor der Aktualisierung nur mit SQL
Problem:
PostgreSQL erlaubt das Abrufen von Voraktualisierungen nicht Spaltenwerte in der RETURNING-Klausel einer UPDATE-Anweisung aktualisieren. Dies stellt eine Herausforderung dar, wenn versucht wird, die alten Werte aktualisierter Spalten zu erhalten, ohne zusätzliche Mechanismen wie Trigger oder Prozeduren einzusetzen.
Lösung mit einem Self-Join:
Eine Lösung besteht darin, einen Self-Join in der FROM-Klausel zu nutzen. Diese Technik erstellt effektiv eine Kopie der Tabelle und ermöglicht die Referenzierung sowohl der aktualisierten als auch der Werte vor der Aktualisierung:
UPDATE tbl x SET tbl_id = 23 , name = 'New Guy' FROM tbl y -- Using the FROM clause WHERE x.tbl_id = y.tbl_id -- Must be UNIQUE NOT NULL AND x.tbl_id = 3 RETURNING y.tbl_id AS old_id, y.name AS old_name , x.tbl_id , x.name;
Diese Methode erfordert eine UNIQUE NOT NULL-Spalte für die Selbstverknüpfung, um sicherzustellen, dass jede Zeile übereinstimmt an ein einzelnes Gegenstück in der verbundenen Instanz.
Lösungen für gleichzeitige Schreiblast:
In In Szenarien mit starker Schreibparallelität gibt es zwei Optionen zur Verhinderung von Race Conditions:
Option 1: SERIALIZABLE-Isolationsstufe:
Die Verwendung der SERIALIZABLE-Isolationsstufe gewährleistet den exklusiven Zugriff auf Zeilen während Transaktionsausführung, wodurch gleichzeitige Schreibvorgänge verhindert werden:
BEGIN ISOLATION LEVEL SERIALIZABLE; UPDATE ... ; COMMIT;
Option 2: Explizit Sperren:
Alternativ kann eine explizite Sperre verwendet werden, um gleichzeitige Aktualisierungen von Zeilen zu verhindern:
UPDATE tbl x SET tbl_id = 24 , name = 'New Gal' FROM (SELECT tbl_id, name FROM tbl WHERE tbl_id = 4 FOR UPDATE) y WHERE x.tbl_id = y.tbl_id RETURNING y.tbl_id AS old_id, y.name AS old_name , x.tbl_id , x.name;
Das obige ist der detaillierte Inhalt vonWie rufe ich alte Spaltenwerte nach einem UPDATE in PostgreSQL nur mit SQL ab?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Dieser Artikel befasst sich mit MySQLs Fehler "Die freigegebene Bibliotheksfehler". Das Problem ergibt sich aus der Unfähigkeit von MySQL, die erforderlichen gemeinsam genutzten Bibliotheken (.SO/.dll -Dateien) zu finden. Lösungen beinhalten die Überprüfung der Bibliotheksinstallation über das Paket des Systems m

In diesem Artikel wird die Optimierung von MySQL -Speicherverbrauch in Docker untersucht. Es werden Überwachungstechniken (Docker -Statistiken, Leistungsschema, externe Tools) und Konfigurationsstrategien erörtert. Dazu gehören Docker -Speichergrenzen, Tausch und CGroups neben

In dem Artikel werden mithilfe der Änderungstabelle von MySQL Tabellen, einschließlich Hinzufügen/Löschen von Spalten, Umbenennung von Tabellen/Spalten und Ändern der Spaltendatentypen, erläutert.

Dieser Artikel vergleicht die Installation von MySQL unter Linux direkt mit Podman -Containern mit/ohne phpmyadmin. Es beschreibt Installationsschritte für jede Methode und betont die Vorteile von Podman in Isolation, Portabilität und Reproduzierbarkeit, aber auch

Dieser Artikel bietet einen umfassenden Überblick über SQLite, eine in sich geschlossene, serverlose relationale Datenbank. Es beschreibt die Vorteile von SQLite (Einfachheit, Portabilität, Benutzerfreundlichkeit) und Nachteile (Parallelitätsbeschränkungen, Skalierbarkeitsprobleme). C

In Artikel werden die Konfiguration der SSL/TLS -Verschlüsselung für MySQL, einschließlich der Erzeugung und Überprüfung von Zertifikaten, erläutert. Das Hauptproblem ist die Verwendung der Sicherheitsauswirkungen von selbstsignierten Zertifikaten. [Charakterzahl: 159]

In diesem Handbuch wird die Installation und Verwaltung mehrerer MySQL -Versionen auf macOS mithilfe von Homebrew nachgewiesen. Es betont die Verwendung von Homebrew, um Installationen zu isolieren und Konflikte zu vermeiden. Der Artikel Details Installation, Starten/Stoppen von Diensten und Best PRA

In Artikel werden beliebte MySQL -GUI -Tools wie MySQL Workbench und PhpMyAdmin beschrieben, die ihre Funktionen und ihre Eignung für Anfänger und fortgeschrittene Benutzer vergleichen. [159 Charaktere]


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

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

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

PHPStorm Mac-Version
Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen
