


Wie kann ich alphanumerische Zeichenfolgen in PostgreSQL menschlich sortieren?
Jan 07, 2025 pm 10:06 PMHumanisierte 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:
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;
PostgreSQL 9.1
In PostgreSQL 9.1 können Sie die folgende Abfrage verwenden:
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 的特殊情况
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!

Heißer Artikel

Hot-Tools-Tags

Heißer Artikel

Heiße Artikel -Tags

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Reduzieren Sie die Verwendung des MySQL -Speichers im Docker

Wie verändern Sie eine Tabelle in MySQL mit der Änderungstabelleanweisung?

So lösen Sie das Problem der MySQL können die gemeinsame Bibliothek nicht öffnen

Führen Sie MySQL in Linux aus (mit/ohne Podman -Container mit Phpmyadmin)

Ausführen mehrerer MySQL-Versionen auf macOS: Eine Schritt-für-Schritt-Anleitung

Wie sichere ich mich MySQL gegen gemeinsame Schwachstellen (SQL-Injektion, Brute-Force-Angriffe)?

Wie konfiguriere ich die SSL/TLS -Verschlüsselung für MySQL -Verbindungen?
