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:
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.
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