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
Freigeben: 2024-12-26 08:39:13
Original
768 Leute haben es durchsucht

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);
Nach dem Login kopieren

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  |
+----+--------+
Nach dem Login kopieren

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);
Nach dem Login kopieren

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  |
+----+--------+
Nach dem Login kopieren

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!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage