Geordnete Ergebnisse aus der „IN“-Klausel in MySQL-Select-Anweisungen
Beim Abfragen großer Tabellen nach bestimmten Datensätzen mithilfe einer „IN“-Klausel wird die Die Standardergebnisreihenfolge kann inkonsistent sein. Um Ergebnisse in derselben Reihenfolge wie die Werte in der „IN“-Klausel zu erhalten, müssen alternative Ansätze zum Überschreiben des Standardverhaltens in Betracht gezogen werden.
Eine Möglichkeit besteht darin, die Funktion FIELD zu verwenden. Diese Funktion benötigt zwei Parameter: Der erste ist die zu sortierende Spalte und der zweite ist eine durch Kommas getrennte Liste von Werten in der gewünschten Sortierreihenfolge. Durch Einschließen der Klausel ORDER BY FIELD(column, Values) in die Abfrage werden die Ergebnisse entsprechend der in der Werteliste angegebenen Wertereihenfolge sortiert.
Zum Beispiel wird die folgende Abfrage abgerufen Datensätze mit IDs in der in der „IN“-Klausel angegebenen Reihenfolge:
SELECT * FROM your_table WHERE id IN (5,2,6,8,12,1) ORDER BY FIELD(id,5,2,6,8,12,1);
Hier sortiert die FIELD-Funktion die „id“-Spalte basierend auf der Reihenfolge der Werte (5, 2, 6, 8, 12, 1). Die Ergebnisse werden in der angegebenen Reihenfolge zurückgegeben, auch bei großen Datensätzen mit Millionen von Zeilen.
Das obige ist der detaillierte Inhalt vonWie ordne ich Ergebnisse aus einer „IN'-Klausel in MySQL an?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!