Publicité
+ Répondre à la discussion
Affichage des résultats 1 à 6 sur 6
  1. #1
    Membre du Club
    Inscrit en
    avril 2002
    Messages
    156
    Détails du profil
    Informations forums :
    Inscription : avril 2002
    Messages : 156
    Points : 46
    Points
    46

    Par défaut Tri numérique avec des caractères associés

    bonjour,

    10,5,3A,2C,2

    et je voudrais avoir ceci :

    2,2C,3A,5,10

    pouvez-vous m'aider. J'ai essayé LPAD CAST mais je n'y arrive pas.

    Merci

  2. #2
    Expert Confirmé Sénior
    Homme Profil pro
    Inscrit en
    mai 2002
    Messages
    2 865
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : mai 2002
    Messages : 2 865
    Points : 4 649
    Points
    4 649

    Par défaut

    Bonjour,

    Un SGBD n'est pas forcément ce qu'il y a de mieux pour trier des occurrences dans une seule et même ligne.

    (c'est même le bordel complet ..)

    Voyez ça côté applicatif

  3. #3
    Membre du Club
    Inscrit en
    avril 2002
    Messages
    156
    Détails du profil
    Informations forums :
    Inscription : avril 2002
    Messages : 156
    Points : 46
    Points
    46

    Par défaut

    Merci pour votre réponse.
    Mais ce n'est pas en une seule ligne. Je représente autrement

    10
    5
    3A
    2C
    2
    et je voudrais avoir ceci :

    2
    2C
    3A
    5
    10

  4. #4
    Expert Confirmé Sénior
    Homme Profil pro
    Inscrit en
    mai 2002
    Messages
    2 865
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : mai 2002
    Messages : 2 865
    Points : 4 649
    Points
    4 649

    Par défaut

    Je ne retrouve pas le poste où on avait déjà traité ce problème, si vous avez le temps de chercher dans ce forum ....


    l'idée est de passer par des expressions régulières afin de sortir la partie numérique de votre chaîne de caractère.

    http://www.postgresql.org/docs/9.1/s...-matching.html

    Code :
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
     
    WITH tmp (a) AS 
    (SELECT '10'::varchar
    union ALL
    SELECT '5'
    union ALL
    SELECT '3A'
    union ALL
    SELECT '2C'
    union ALL
    SELECT '2')
     
    SELECT substring(a, '[0-9]*')::varchar::numeric, a
    FROM tmp
    ORDER BY substring(a, '[0-9]*')::varchar::numeric, a

  5. #5
    Membre du Club
    Inscrit en
    avril 2002
    Messages
    156
    Détails du profil
    Informations forums :
    Inscription : avril 2002
    Messages : 156
    Points : 46
    Points
    46

    Par défaut

    Je viens de trouver une solution :

    Code :
    ORDER BY c.acpadrzip,UPPER(c.acpadrcity),UPPER(c.acpaddress),CASE WHEN (TRIM(acpadrnum)>='00000' AND TRIM(acpadrnum)<='99999') THEN TO_NUMBER(acpadrnum,'99999') ELSE 0 END,TRIM(UPPER(acpadrnum)),TRIM(UPPER(acpadrbox));
    Merci encore

  6. #6
    Membre Expert
    Homme Profil pro Sylvain Devidal
    Chef de projets Générix
    Inscrit en
    février 2010
    Messages
    1 573
    Détails du profil
    Informations personnelles :
    Nom : Homme Sylvain Devidal
    Âge : 35
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets Générix
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : février 2010
    Messages : 1 573
    Points : 2 403
    Points
    2 403

    Par défaut

    y dit qu'y voit pas l'rapport
    Sinon, ce que vous cherchez à faire, c'est un tri "naturel" ou "natural sort".

    Aucun SGBD à ma connaissance n'implémente ce système de tri.
    Et ce n'est pas au SGBD de faire ce genre de tri, qui est purement esthétique.

    Vous avez trouvé la solution en faisant un tri par d'autres informations que le libellé initial, et c'est effectivement la bonne solution.

+ Répondre à la discussion
Cette discussion est résolue.

Liens sociaux

Règles de messages

  • Vous ne pouvez pas créer de nouvelles discussions
  • Vous ne pouvez pas envoyer des réponses
  • Vous ne pouvez pas envoyer des pièces jointes
  • Vous ne pouvez pas modifier vos messages
  •