„Wenn ein Arbeiter seine Arbeit gut machen will, muss er zuerst seine Werkzeuge schärfen.“ – Konfuzius, „Die Gespräche des Konfuzius. Lu Linggong“
Titelseite > Programmierung > Wie ordne ich SQL-Ergebnisse basierend auf der Reihenfolge der WHERE IN-Klauseln?

Wie ordne ich SQL-Ergebnisse basierend auf der Reihenfolge der WHERE IN-Klauseln?

Veröffentlicht am 08.11.2024
Durchsuche:213

How to Order SQL Results Based on WHERE IN Clause Order?

Ergebnisse nach der Reihenfolge der WHERE IN-Klausel sortieren

Bei Verwendung der WHERE IN-Klausel in SQL werden die Ergebnisse normalerweise nach der natürlichen Reihenfolge der Spalte sortiert Reihenfolge (normalerweise aufsteigend). In bestimmten Szenarien möchten Sie jedoch möglicherweise, dass die Zeilen in derselben Reihenfolge zurückgegeben werden, wie in der IN-Klausel angegeben.

Lösung: Sortieren nach Feld

Zum Sortieren Um Zeilen entsprechend der in der WHERE IN-Klausel angegebenen Reihenfolge zu sortieren, können Sie die Funktion ORDER BY FIELD verwenden. Diese Funktion benötigt zwei Argumente:

  • Die Spalte, nach der sortiert werden soll
  • Eine Liste von Werten, die die gewünschte Reihenfolge darstellen

In diesem Fall können Sie verwenden Führen Sie die folgende Abfrage aus, um die Ergebnisse nach der ID-Spalte in der in der IN-Klausel angegebenen Reihenfolge zu sortieren:

SELECT *
FROM table
WHERE id IN (118, 17, 113, 23, 72)
ORDER BY FIELD(id, 118, 17, 113, 23, 72);

Diese Abfrage gibt die Zeilen in der folgenden Reihenfolge zurück: 118, 17, 113, 23, 72.

Neuestes Tutorial Mehr>

Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.

Copyright© 2022 湘ICP备2022001581号-3