Beibehalten der Reihenfolge in MySQL-„IN“-Abfragen
In MySQL wählt der „IN“-Operator Datensätze aus, die mit einem beliebigen Wert in einer bereitgestellten Liste übereinstimmen . Standardmäßig werden die Ergebnisse in der durch den Sortieralgorithmus der Datenbank definierten Reihenfolge zurückgegeben, die möglicherweise nicht immer mit der in der Abfrage angegebenen Reihenfolge übereinstimmt.
Betrachten wir das folgende Beispiel:
SELECT * FROM foo f WHERE f.id IN (2, 3, 1);
Diese Abfrage zielt darauf ab, Datensätze mit den IDs 2, 3 und 1 abzurufen. Die Ergebnisse werden jedoch normalerweise nach ID sortiert aufsteigend:
+----+--------+ | id | name | +----+--------+ | 1 | first | | 2 | second | | 3 | third | +----+--------+
Um die in der Abfrage angegebene Reihenfolge beizubehalten, müssen wir die Ergebnisse explizit ordnen. Die Funktion ORDER BY FIELD() kann dies erreichen.
SELECT * FROM foo f WHERE f.id IN (2, 3, 1) ORDER BY FIELD(f.id, 2, 3, 1);
Die Funktion FIELD() verwendet einen Wert als erstes Argument und eine Liste von Werten als verbleibende Argumente. Es gibt die Position des Werts in der Liste zurück. Beispielsweise gibt FIELD(2, 2, 3, 1) 1 zurück, da 2 der erste Wert in der Liste ist.
Indem wir die Ergebnisse nach FIELD(f.id, 2, 3, 1) ordnen, können wir Weisen Sie MySQL an, die Datensätze zunächst nach ihrem ersten Wert (2), dann nach ihrem zweiten Wert (3) und schließlich nach ihrem dritten Wert (1) zu sortieren. Diese Reihenfolge stellt sicher, dass die Ergebnisse in derselben Reihenfolge zurückgegeben werden, in der sie in der Abfrage erscheinen.
+----+--------+ | id | name | +----+--------+ | 2 | second | | 3 | third | | 1 | first | +----+--------+
Das obige ist der detaillierte Inhalt vonWie behält man die Reihenfolge der Werte in einer MySQL-IN-Abfrage bei?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!