Heim  >  Artikel  >  Datenbank  >  Wie tausche ich Zeilenwerte in MySQL mit einer eindeutigen Einschränkung aus, ohne die Integrität zu verletzen?

Wie tausche ich Zeilenwerte in MySQL mit einer eindeutigen Einschränkung aus, ohne die Integrität zu verletzen?

Linda Hamilton
Linda HamiltonOriginal
2024-10-26 00:23:28152Durchsuche

How to Swap Row Values in MySQL with a Unique Constraint Without Violating Integrity?

Austauschen von Zeilenwerten in MySQL unter Beibehaltung der eindeutigen Einschränkung

In MySQL ist die Aufgabe des Austauschens von Prioritätswerten zwischen zwei Zeilen in einer Tabelle mit a Bei der eindeutigen Einschränkung können aufgrund von Einschränkungsverletzungen Fehler auftreten. Um das Problem zu verstehen, untersuchen wir eine typische UPDATE-Anweisung:

UPDATE tasks 
SET priority = 
CASE
    WHEN priority=2 THEN 3 
    WHEN priority=3 THEN 2 
END 

WHERE priority IN (2,3);

Diese Aussage führt jedoch zu einem Fehler:

Error Code: 1062. Duplicate entry '3' for key 'priority_UNIQUE'

Art des Problems

MySQL verarbeitet Aktualisierungen anders als andere DBMS. Die Prüfung auf Einschränkungsverletzungen erfolgt nach jeder Zeilenaktualisierung und nicht erst nach Abschluss der gesamten Anweisung. Daher verstößt das Austauschen von Werten direkt gegen die Eindeutigkeitsbeschränkung.

Alternativen ohne falsche Werte oder mehrere Abfragen

Leider gibt es keine Möglichkeit, diesen Vorgang ohne die Verwendung von auszuführen Zwischenwert (falsch oder null) oder mehrere Abfragen in MySQL. Die Eindeutigkeitsbeschränkung erzwingt die Eindeutigkeit nach jeder Zeilenaktualisierung und macht einen direkten Austausch unmöglich.

Vorübergehende Entfernung der Beschränkung

Eine Möglichkeit besteht darin, die Eindeutigkeitsbeschränkung vorübergehend zu entfernen und den Austauschvorgang auszuführen , und fügen Sie dann die Einschränkung erneut hinzu. Dieser Ansatz wird jedoch nicht empfohlen, da er die Datenintegrität beeinträchtigt.

Falsche Werte und mehrere Abfragen

Der empfohlene Ansatz beinhaltet die vorübergehende Verwendung eines falschen Werts (-3). Halten Sie den Prioritätswert der ersten Zeile und tauschen Sie ihn mit dem Wert der zweiten Zeile aus. Es sind zwei Abfragen innerhalb einer Transaktion erforderlich:

START TRANSACTION ;
    UPDATE tasks 
    SET priority = 
      CASE
        WHEN priority = 2 THEN -3 
        WHEN priority = 3 THEN -2 
      END 
    WHERE priority IN (2,3) ;

    UPDATE tasks 
    SET priority = - priority
    WHERE priority IN (-2,-3) ;
COMMIT ;

Dieser Prozess stellt sicher, dass die Einschränkung während des Swap-Vorgangs nicht verletzt wird.

Das obige ist der detaillierte Inhalt vonWie tausche ich Zeilenwerte in MySQL mit einer eindeutigen Einschränkung aus, ohne die Integrität zu verletzen?. 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