Heim >Datenbank >MySQL-Tutorial >Wie tausche ich Zeilenwerte in MySQL mit einer eindeutigen Einschränkung aus, ohne die Integrität zu verletzen?
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!