Heim > Datenbank > MySQL-Tutorial > Wie kann ich benutzerdefinierte Sortierreihenfolgen in MySQL priorisieren?

Wie kann ich benutzerdefinierte Sortierreihenfolgen in MySQL priorisieren?

Linda Hamilton
Freigeben: 2024-12-14 08:11:11
Original
586 Leute haben es durchsucht

How Can I Prioritize Custom Sorting Orders in MySQL?

Anpassen der Sortierpriorität in MySQL

In MySQL können Sie durch die Definition einer benutzerdefinierten Sortierreihenfolge bestimmte Kriterien beim Abrufen von Daten priorisieren. Eine dieser Aufgaben besteht darin, eine Tabelle mit mehreren Werten in einer Spalte zu sortieren.

Betrachten Sie die folgende Tabelle:

ID  Language    Text
0   ENU         a
0   JPN         b
0   DAN         c       
1   ENU         d
1   JPN         e
1   DAN         f
2   etc...
Nach dem Login kopieren

Um Daten nach Sprache und aufsteigender ID sortiert abzurufen, wobei ENU die erste Priorität hat , JPN als zweites und DAN als drittes verwenden, können Sie die FIELD()-Funktion von MySQL verwenden. Diese Funktion weist jedem Sprachwert basierend auf der angegebenen Reihenfolge eine Position zu.

Hier ist die Abfrage, um dies zu erreichen:

SELECT *
FROM table_name
ORDER BY FIELD(Language, 'ENU', 'JPN', 'DAN'), ID;
Nach dem Login kopieren

Dadurch werden die Daten in der folgenden Reihenfolge zurückgegeben: a, d , b, e, c, f. Es ist jedoch wichtig zu beachten, dass:

  • Die Verwendung von FIELD() die Portabilität beeinträchtigen kann, da andere DBMS diese Funktion möglicherweise nicht unterstützen.
  • Für erweiterte Wertelisten ist es vorzuziehen, diese zu erstellen eine separate Tabelle mit einer „sortOrder“-Spalte. Durch die Verknüpfung dieser Tabelle mit der Haupttabelle können Sie eine benutzerdefinierte Sortierung ohne die Einschränkungen von FIELD() erreichen.

Das obige ist der detaillierte Inhalt vonWie kann ich benutzerdefinierte Sortierreihenfolgen 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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage