Einzelnen Beitrag anzeigen

Benutzerbild von yankee
yankee

Registriert seit: 10. Mär 2004
1.134 Beiträge
 
Lazarus
 
#1

Dreieckstausch? (Daten 2er Datensätze vertauschen)

  Alt 18. Jan 2007, 21:36
Datenbank: MySQL • Version: 5.0.27 • Zugriff über: unwichtig
Hi @ll,

Ich habe mal vereinfacht dargestellt folgende Tabelle:

id INT auto_inkrement
spalte INT
PRIMARY KEY(id)
UNIQUE KEY(spalte)

Mit volgendem Inhalt:
Code:
id  spalte
1      3
2      4
Jetzt will ich den Wert von "Spalte" der beiden Datensätze vertauschen, damit die Tabelle nachher so aussieht:
Code:
id  spalte
1      4
2      3
Gibt es für dieses Problem irgend eine schlauere Lösung, als Spalte bei einem der beiden erstmal auf einen temporären Wert, der auch ganz sich sonst nicht in der Tabelle vorkommt zu setzen, dann den zweiten Wert auf den ersten upzudaten und dann wieder den ersten auf den zweiten?

Ich habe schonmal an sowas gedacht:

UPDATE tabelle SET spalte=IF(spalte=4,3,4) WHERE id=3 OR id=4 Aber das geht natürlich so auch nicht. Ich müsste quasi nur dafür den key einmal kurz deaktivieren...

Oder sollte ich bei sowas doch lieber einfach einen KEY nehmen statt einen UNIQUE KEY?
Ist UNIQUE KEY überhaupt Geschwindigkeitsmässig ein Vorteil?
Letzter Tipp: Drogen. Machen zwar nicht glücklich, geben einem aber wenigstens das Gefühl glücklich zu sein.

Have a lot of fun!
  Mit Zitat antworten Zitat