Heim >Datenbank >MySQL-Tutorial >Wie sortiere ich String-Zahlen numerisch in MySQL?

Wie sortiere ich String-Zahlen numerisch in MySQL?

Patricia Arquette
Patricia ArquetteOriginal
2025-01-12 18:42:43274Durchsuche

How to Sort Stringified Numbers Numerically in MySQL?

String-Nummern nach numerischem Wert in MySQL sortieren

Beim Umgang mit Zahlen, die als Zeichenfolgen in einer MySQL-Datenbank gespeichert sind, kann das Sortieren nach numerischer Größe schwierig sein. Die folgenden Fragen verdeutlichen das Problem:

Frage:

Wie sortiere ich eine Spalte, die Zeichenfolgenzahlen enthält, in aufsteigender Reihenfolge und zwar nach ihrer numerischen Größe und nicht nach ihrer Zeichendarstellung?

Antwort:

Das explizite oder implizite Konvertieren von Zeichenfolgenwerten in Ganzzahlen ermöglicht eine korrekte numerische Reihenfolge:

Explizite Konvertierung:

<code class="language-sql">SELECT col
FROM yourtable
ORDER BY CAST(col AS UNSIGNED)</code>

In diesem Beispiel konvertiert CAST die Spalte „col“ vor dem Sortieren in eine vorzeichenlose Ganzzahl.

Implizite Konvertierung:

<code class="language-sql">SELECT col
FROM yourtable
ORDER BY col + 0</code>

Das Hinzufügen von 0 zwingt MySQL, col vor dem Sortieren als numerischen Wert zu interpretieren.

Hinweis:

MySQL interpretiert Zeichenfolgen zur Konvertierung von links nach rechts. Zum Beispiel:

  • „1“ wird in 1 umgewandelt.
  • „ABC“ wird in 0 umgewandelt (keine führende Ziffer).
  • „123 Meilen“ wird in 123 umgewandelt.
  • „$123“ wird in 0 umgewandelt (das erste Zeichen ist keine Zahl).

Das obige ist der detaillierte Inhalt vonWie sortiere ich String-Zahlen numerisch in MySQL?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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