Heim >Datenbank >MySQL-Tutorial >Wie behält man die Reihenfolge der Werte in einer MySQL-IN-Abfrage bei?

Wie behält man die Reihenfolge der Werte in einer MySQL-IN-Abfrage bei?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2024-12-26 08:39:13804Durchsuche

How to Preserve the Order of Values in a MySQL `IN` Query?

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!

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