Heim > Datenbank > MySQL-Tutorial > Wie kann ich bestimmte Feldwerte beim Bestellen von Daten in MySQL priorisieren?

Wie kann ich bestimmte Feldwerte beim Bestellen von Daten in MySQL priorisieren?

DDD
Freigeben: 2025-01-14 09:30:45
Original
438 Leute haben es durchsucht

How Can I Prioritize Specific Field Values When Ordering Data in MySQL?

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>
Nach dem Login kopieren

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>
Nach dem Login kopieren

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>
Nach dem Login kopieren

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!

Quelle:php.cn
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage