recherche
Maisonbase de donnéestutoriel mysqlComment puis-je effectuer un tri naturel de chaînes alphabétiques et numériques mixtes dans PostgreSQL ?

How Can I Perform Natural Sorting of Mixed Alphabetic and Numeric Strings in PostgreSQL?

Tri naturel des chaînes alphanumériques mixtes PostgreSQL

Un défi inhérent au tri naturel de chaînes alphanumériques mixtes est de maintenir l'ordre des mots tout en traitant les nombres comme des nombres entiers. Dans PostgreSQL 9.1 et supérieur, une méthode pratique existe :

Types composites et opérations sur les tableaux :

  1. Créez un type composite appelé "ai" qui contient un champ de texte "a" et un champ entier "i".
  2. Divisez chaque chaîne en un tableau de valeurs "ai" à l'aide de la fonction "regexp_matches".

Exemple de requête (PostgreSQL 9.4 et versions ultérieures) :

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;

Comment gérer PostgreSQL 9.1 :

Dans les anciennes versions de PostgreSQL, la requête doit être légèrement modifiée :

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;

Avec cette approche, le fractionnement de chaînes et le tri naturel deviennent réalisables dans PostgreSQL, permettant un tri intuitif de divers ensembles de données contenant des chaînes alphanumériques mixtes.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Types de chaînes MySQL: stockage, performances et meilleures pratiquesTypes de chaînes MySQL: stockage, performances et meilleures pratiquesMay 10, 2025 am 12:02 AM

MysqlStringTypeSimpactStorageAndPerformanceSfollows: 1) Charisfixed-Length, AlwaysusingTheSameStoragespace, qui, de manière morépace-efficace sans espace.

Comprendre les types de chaînes MySQL: varchar, texte, char, et plus encoreComprendre les types de chaînes MySQL: varchar, texte, char, et plus encoreMay 10, 2025 am 12:02 AM

MysqlstringTypeSincludevarchar, text, char, énum, ​​andset.1) varcharinsversatileforvariable-LengthstringSuptoSpecifiedImmit.2)

Quels sont les types de données de chaîne dans MySQL?Quels sont les types de données de chaîne dans MySQL?May 10, 2025 am 12:01 AM

MysqloffersvariousStringDatatypes: 1) Charforfixed-LengthStrings, 2) varcharforvariable-LengthText, 3) binaryandvarbinaryforbinarydata, 4) blobandtextforlatedata, and5) enumandsetfor.

Comment accorder des autorisations aux nouveaux utilisateurs de MySQLComment accorder des autorisations aux nouveaux utilisateurs de MySQLMay 09, 2025 am 12:16 AM

TOGRANTERMISSIMESTESTERSWMYSQLUSERS, SuivreTheSesteps: 1) AccessMysqlasauserwithSufficientPrivileges, 2) CreateEnewUserwithThereAserercommand, 3) UsethegrantCommandTospecifyPerMissionsLikEselect, insert, mise à jour, OrallegandSonSpecificaCificdataStAtAnSorables, et4), 4).

Comment ajouter des utilisateurs dans MySQL: un guide étape par étapeComment ajouter des utilisateurs dans MySQL: un guide étape par étapeMay 09, 2025 am 12:14 AM

ToaddUsersInmysqleffecativement et en résultant, suivez-vous: 1) UsethCreateAsTatement à AddanEwUser, spécifiant le dossier d'astron.

MySQL: ajout d'un nouvel utilisateur avec des autorisations complexesMySQL: ajout d'un nouvel utilisateur avec des autorisations complexesMay 09, 2025 am 12:09 AM

ToaddanewUserwithComplexPermisessionsInmysql, suivi destiné: 1) Création sword ';. 2) GRANTREADACCESSTOALLTABLESSIn'MYDATABASE'WithGrantsElectonMyDatabase.To'newuser' @ 'LocalHost';. 3) GRANTWRITEACESSTO '

MySQL: Types et collations de données de chaîneMySQL: Types et collations de données de chaîneMay 09, 2025 am 12:08 AM

Les types de données de chaîne dans MySQL incluent Char, Varchar, Binary, Varbinary, Blob et Text. Les collations déterminent la comparaison et le tri des chaînes. 1. Char convient aux chaînes de longueur fixe, Varchar convient aux chaînes de longueur variable. 2.Binara et varbinaire sont utilisés pour les données binaires, et Blob et le texte sont utilisés pour les données de grandes objets. 3. Les règles de tri telles que UTF8MB4_UNICODE_CI ignorent les caractéristiques supérieures et inférieures et conviennent aux noms d'utilisateurs; UTF8MB4_BIN est sensible à la casse et convient aux champs qui nécessitent une comparaison précise.

MySQL: Quelle longueur dois-je utiliser pour Varchars?MySQL: Quelle longueur dois-je utiliser pour Varchars?May 09, 2025 am 12:06 AM

La meilleure sélection de la longueur de la colonne MySqlvarchar doit être basée sur l'analyse des données, considérer la croissance future, évaluer les impacts des performances et les exigences des ensembles de caractères. 1) Analyser les données pour déterminer les longueurs typiques; 2) Réserver l'espace d'expansion future; 3) Faites attention à l'impact de grandes longueurs sur les performances; 4) Considérez l'impact des ensembles de caractères sur le stockage. Grâce à ces étapes, l'efficacité et l'évolutivité de la base de données peuvent être optimisées.

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

MantisBT

MantisBT

Mantis est un outil Web de suivi des défauts facile à déployer, conçu pour faciliter le suivi des défauts des produits. Cela nécessite PHP, MySQL et un serveur Web. Découvrez nos services de démonstration et d'hébergement.

Télécharger la version Mac de l'éditeur Atom

Télécharger la version Mac de l'éditeur Atom

L'éditeur open source le plus populaire

DVWA

DVWA

Damn Vulnerable Web App (DVWA) est une application Web PHP/MySQL très vulnérable. Ses principaux objectifs sont d'aider les professionnels de la sécurité à tester leurs compétences et leurs outils dans un environnement juridique, d'aider les développeurs Web à mieux comprendre le processus de sécurisation des applications Web et d'aider les enseignants/étudiants à enseigner/apprendre dans un environnement de classe. Application Web sécurité. L'objectif de DVWA est de mettre en pratique certaines des vulnérabilités Web les plus courantes via une interface simple et directe, avec différents degrés de difficulté. Veuillez noter que ce logiciel

Version Mac de WebStorm

Version Mac de WebStorm

Outils de développement JavaScript utiles

Version crackée d'EditPlus en chinois

Version crackée d'EditPlus en chinois

Petite taille, coloration syntaxique, ne prend pas en charge la fonction d'invite de code