MySQL-Datensortierung: Priorisieren Sie bestimmte Feldwerte
Wenn Sie in MySQL die Ergebnismenge nach bestimmten Feldwerten sortieren und bestimmte Werte priorisieren müssen, können Sie die Funktion FIELD
verwenden. Mit dieser Funktion können Sie die Reihenfolge angeben, in der Werte in den sortierten Ergebnissen angezeigt werden.
Betrachten Sie beispielsweise die folgende Tabelle:
id | name | priority |
---|---|---|
1 | core | 10 |
2 | core | 9 |
3 | other | 8 |
4 | board | 7 |
5 | board | 6 |
6 | core | 4 |
Um Zeilen nach Priorität zu sortieren und dabei Zeilen Priorität zu geben, bei denen das Feld „Name“ gleich „Kern“ ist, können Sie die folgende Abfrage verwenden:
<code class="language-sql">SELECT id, name, priority FROM mytable ORDER BY FIELD(name, "core", "board", "other")</code>
Diese Abfrage stellt sicher, dass Zeilen, deren „Name“ auf „Kern“ gesetzt ist, unabhängig von ihrem Prioritätswert zuerst angezeigt werden. Als nächstes kommt die Zeile, in der „name“ auf „board“ gesetzt ist, gefolgt von der Zeile, in der „name“ auf „other“ gesetzt ist.
Beachten Sie, dass Sie die folgende Abfrage verwenden können, wenn Ihnen nur die Priorisierung von „Kern“-Zeilen am Herzen liegt und Ihnen die Reihenfolge der anderen Werte egal ist:
<code class="language-sql">SELECT id, name, priority FROM mytable ORDER BY FIELD(name, "core") DESC</code>
In diesem Fall erscheint die Zeile „Kern“ zuerst und die anderen Werte werden in absteigender Reihenfolge sortiert.
Wenn Sie schließlich zuerst nach „Kern“ sortieren und dann die normale Sortierreihenfolge auf die anderen Felder anwenden möchten, können Sie diese Abfrage verwenden:
<code class="language-sql">SELECT id, name, priority FROM mytable ORDER BY FIELD(name, "core") DESC, priority</code>
Denken Sie daran, dass FIELD
Funktionen MySQL-spezifisch sind. Darüber hinaus wird der nullbasierte Index des Werts zurückgegeben. Wenn der angegebene Wert nicht in der Liste enthalten ist, wird Null zurückgegeben. Daher ist es wichtig, diese Überlegungen zu berücksichtigen, wenn Sie die Funktion FIELD
zum Sortieren von Daten in MySQL verwenden.
Das obige ist der detaillierte Inhalt vonWie kann ich bestimmte Feldwerte beim Bestellen von Daten in MySQL priorisieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!