Heim > Datenbank > MySQL-Tutorial > Wie kann ich alphanumerische Zeichenfolgen in PostgreSQL menschlich sortieren?

Wie kann ich alphanumerische Zeichenfolgen in PostgreSQL menschlich sortieren?

Patricia Arquette
Freigeben: 2025-01-07 22:06:46
Original
221 Leute haben es durchsucht

How Can I Sort Alphanumeric Strings Humanely in PostgreSQL?

Humanisierte String-Sortierung in PostgreSQL

Das menschliche Sortieren von Zeichenfolgen, die eine Mischung aus Buchstaben und Zahlen enthalten, kann in PostgreSQL eine Herausforderung sein, kann aber mit einer Kombination aus regexp_matches() und Array-Aggregation erreicht werden.

Zeichenfolge teilen

Der erste Schritt besteht darin, jede Zeichenfolge in ihre alphabetischen und numerischen Bestandteile aufzuteilen. Dies kann mit der Funktion regexp_matches() und regulären Ausdrücken wie (D*)(d*) erfolgen. Das resultierende Array von Übereinstimmungen kann dann iteriert werden, um ein Array von Paaren zu erstellen, wobei jedes Paar einen Textwert und einen ganzzahligen Wert enthält.

Sortieren Sie diese Paare

Der nächste Schritt besteht darin, diese Wertepaare nach der gewünschten menschenfreundlichen Reihenfolge zu sortieren. Textwerte können in der normalen Zeichenfolgensortierreihenfolge sortiert werden, während Ganzzahlwerte als Ganzzahlen sortiert werden können.

Strings neu kombinieren

Schließlich können die sortierten Paare verwendet werden, um die ursprüngliche Zeichenfolge in der gewünschten personalisierten Reihenfolge wieder zusammenzusetzen.

PostgreSQL 9.4 oder höher

In PostgreSQL 9.4 oder höher kann die folgende Abfrage verwendet werden:

<code class="language-sql">SELECT data
FROM   alnum
ORDER  BY ARRAY(SELECT ROW(x[1], CASE x[2] WHEN '' THEN '0' ELSE x[2] END)::ai
                FROM regexp_matches(data, '(\D*)(\d*)', 'g') x)
        , data;</code>
Nach dem Login kopieren

PostgreSQL 9.1

In PostgreSQL 9.1 können Sie die folgende Abfrage verwenden:

<code class="language-sql">SELECT data
FROM  (
    SELECT ctid, data, regexp_matches(data, '(\D*)(\d*)', 'g') AS x
    FROM   alnum
    ) x
GROUP  BY ctid, data   -- ctid 作为缺少主键的替代
ORDER  BY regexp_replace (left(data, 1), '[0-9]', '0')
        , array_agg(ROW(x[1], CASE x[2] WHEN '' THEN '0' ELSE x[2] END)::ai)
        , data         -- 用于处理尾随 0 的特殊情况</code>
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie kann ich alphanumerische Zeichenfolgen in PostgreSQL menschlich sortieren?. 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