Heim >Datenbank >MySQL-Tutorial >Wie kann ich Spaltenwerte vor der Aktualisierung in SQL ohne Trigger oder gespeicherte Prozeduren abrufen?

Wie kann ich Spaltenwerte vor der Aktualisierung in SQL ohne Trigger oder gespeicherte Prozeduren abrufen?

Linda Hamilton
Linda HamiltonOriginal
2025-01-04 07:33:34800Durchsuche

How Can I Retrieve Pre-Update Column Values in SQL Without Triggers or Stored Procedures?

Abrufen von Spaltenwerten vor der Aktualisierung ausschließlich mit SQL

Abrufen der ursprünglichen Werte von Spalten in einer Zeile nach einer Aktualisierung ohne Verwendung von Triggern, gespeichert Prozeduren oder andere externe Entitäten ist eine wiederkehrende Herausforderung in SQL. Um dieses Problem anzugehen, untersuchen wir verschiedene Ansätze.

Erste Versuche und Nachteile

Wie in der ursprünglichen Frage erwähnt, wird FOR UPDATE mit einer Unterabfrage verwendet Das Enthalten einer GROUP BY-Klausel ist nicht möglich. Verknüpfungen werden dadurch nicht mehr funktionsfähig.

Lösung mit einem Tabellenalias

Die einfachste Lösung besteht darin, die Tabelle mithilfe eines Tabellenalias mit sich selbst zu verbinden. Durch Aliasing der Tabelle können wir sowohl auf die ursprünglichen als auch auf die aktualisierten Werte zugreifen. Betrachten Sie die folgende Aktualisierungsabfrage:

UPDATE my_table x
SET processing_by = our_id_info
FROM my_table y
WHERE x.trans_nbr = y.trans_nbr
AND x.row_id = y.row_id
RETURNING y.processing_by AS old_processing_by, x.processing_by;

Verarbeitung gleichzeitiger Schreibvorgänge

Um zu verhindern, dass gleichzeitige Schreibvorgänge das Ergebnis beeinflussen, können wir FOR UPDATE verwenden -Klausel in einer Unterabfrage. Dadurch wird sichergestellt, dass nur die durch die Unterabfrage gesperrte Zeile verarbeitet wird.

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;

Weitere Überlegungen

  • Die für den Selbstjoin verwendeten Spalten müssen eindeutig sein und nicht null.
  • Es ist entscheidend, die Parallelitätsanforderungen des genau zu erfassen Anwendung.
  • Die Verwendung der Isolationsstufe SERIALIZABLE kann zuverlässige gleichzeitige Aktualisierungen auf Kosten der Leistung gewährleisten.
  • Alternativ kann eine explizite Sperrung mit FOR UPDATE erfolgen sorgen für ein Gleichgewicht zwischen Zuverlässigkeit und Leistung.

Das obige ist der detaillierte Inhalt vonWie kann ich Spaltenwerte vor der Aktualisierung in SQL ohne Trigger oder gespeicherte Prozeduren abrufen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn