Austauschen von MySQL-Spaltenwerten mit eingeschränkten Berechtigungen
Das Aktualisieren von Spaltenwerten ohne Erlaubnis zum Ändern der Datenbankstruktur kann eine Herausforderung darstellen. Der intuitive Ansatz, eine UPDATE-Anweisung zum Austauschen von Werten zu verwenden, z. B. die UPDATE-Tabelle SET X=Y, Y=X, reicht nicht aus. Ziehen Sie stattdessen die folgenden Methoden in Betracht, die strukturelle Änderungen umgehen:
Methode 1
Verwenden Sie eine temporäre Variable, um einen Wert zu speichern, während Sie den anderen Wert zuweisen. Dadurch wird sichergestellt, dass beide Werte nicht mit denselben Daten überschrieben werden.
UPDATE swap_test SET x=y, y=@temp WHERE (@temp:=x) IS NOT NULL;
Methode 2
Werte mithilfe einer Reihe von Zuweisungen austauschen. Diese Methode verarbeitet sowohl NULL- als auch Nicht-NULL-Werte elegant.
UPDATE swap_test SET x=(@temp:=x), x = y, y = @temp;
Methode 3
Verwenden Sie die Selbstverknüpfung, um Werte über zwei Tabellenverweise hinweg zu aktualisieren. Diese Methode erfordert einen Primärschlüssel oder einen eindeutigen Index.
UPDATE swap_test s1, swap_test s2 SET s1.x=s1.y, s1.y=s2.x WHERE s1.id=s2.id;
Jede Methode bietet einzigartige Vorteile und Einschränkungen. Methode 1 kann Nicht-NULL-Werte verarbeiten, während Methode 2 sowohl NULL- als auch Nicht-NULL-Werte verarbeiten kann. Methode 3 erfordert einen Primärschlüssel, ermöglicht aber bei Bedarf den Austausch zwischen verschiedenen Zeilen. Letztendlich hängt die beste Vorgehensweise von den spezifischen Anforderungen der jeweiligen Aufgabe ab.
Das obige ist der detaillierte Inhalt vonWie kann ich MySQL-Spaltenwerte ohne ALTER TABLE-Berechtigungen austauschen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!