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>
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>
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!