Heim >Datenbank >MySQL-Tutorial >Wie sortiere ich Ergebnisse nach der Reihenfolge der Werte in einer „IN'-Klausel in MySQL?

Wie sortiere ich Ergebnisse nach der Reihenfolge der Werte in einer „IN'-Klausel in MySQL?

Barbara Streisand
Barbara StreisandOriginal
2024-11-04 05:15:29963Durchsuche

How to Sort Results by Order of Values in an

So sortieren Sie Ergebnisse nach der Reihenfolge der Werte in der „IN“-Klausel einer SELECT-Anweisung in MySQL

Beim Abrufen einer Reihe von Datensätzen mit einer Wenn Sie in einer SELECT-Anweisung eine „IN“-Klausel verwenden, stimmt die resultierende Reihenfolge der Zeilen möglicherweise nicht mit der Reihenfolge der in der Klausel angegebenen Werte überein, sodass die Ergebnisse ungeordnet bleiben. Um dieses Problem zu lösen, besteht ein gängiger Ansatz darin, eine temporäre Tabelle einzurichten und eine Join-Operation einzusetzen. Es gibt jedoch eine einfachere und effizientere Lösung.

Mit der FIELD()-Funktion können Sie die gewünschte Sortierreihenfolge innerhalb der „IN“-Klausel selbst angeben. Diese Funktion wertet einen Wert anhand einer Liste bereitgestellter Argumente aus und gibt die Position des ersten Arguments zurück, mit dem er übereinstimmt. Indem Sie die Argumente in der gewünschten Reihenfolge anordnen, können Sie die Ergebnisse effektiv basierend auf den Werten in der „IN“-Klausel sortieren.

Betrachten Sie beispielsweise die folgende SELECT-Anweisung:

<code class="sql">SELECT * FROM your_table
WHERE id IN (5,2,6,8,12,1);</code>

Um die Ergebnisse in der Reihenfolge der in der „IN“-Klausel angegebenen Werte zu sortieren, können Sie die Abfrage wie folgt ändern:

<code class="sql">SELECT * FROM your_table
WHERE id IN (5,2,6,8,12,1)
ORDER BY FIELD(id,5,2,6,8,12,1);</code>

Indem Sie die Werte in der gewünschten Sortierreihenfolge als Argumente für das Feld FIELD( angeben) )-Funktion werden die Ergebnisse in genau dieser Reihenfolge zurückgegeben. Dadurch entfällt die Notwendigkeit einer temporären Tabelle und eines Joins, was eine einfachere und effizientere Lösung zum Ordnen von Ergebnissen basierend auf „IN“-Klauselwerten bietet.

Das obige ist der detaillierte Inhalt vonWie sortiere ich Ergebnisse nach der Reihenfolge der Werte in einer „IN'-Klausel in MySQL?. 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