IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Requêtes MySQL Discussion :

Type de champ x.x.x.x [MySQL-5.6]


Sujet :

Requêtes MySQL

  1. #1
    Membre à l'essai
    Inscrit en
    Juin 2010
    Messages
    62
    Détails du profil
    Informations forums :
    Inscription : Juin 2010
    Messages : 62
    Points : 24
    Points
    24
    Par défaut Type de champ x.x.x.x
    Bonjour,
    Je cherche à savoir s'il existe un type de champ capable de trier des numérotation :
    1.1.1
    1.1.2
    ... etc

    Pour le moment je le fait en VARCHAR le problème est que lorsque je trie dans un ordre donne ceci par ex :

    1.1.1
    ...
    1.10.1
    ...
    1.2.1
    1.3.1

    Le 1.10.1 vient s’intercaler.

    Y a t'il une autre solution ?

    Merci

  2. #2
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    bonjour,


    il faut splitter vos chaine en fonction des "." et faire un order by sur ces différents résultats.


    Regardez dans les fonctions de chaine de MySql : http://dev.mysql.com/doc/refman/5.6/...functions.html

  3. #3
    Membre à l'essai
    Inscrit en
    Juin 2010
    Messages
    62
    Détails du profil
    Informations forums :
    Inscription : Juin 2010
    Messages : 62
    Points : 24
    Points
    24
    Par défaut
    Parfait merci.
    J'y avais pas pensé.

  4. #4
    Membre à l'essai
    Inscrit en
    Juin 2010
    Messages
    62
    Détails du profil
    Informations forums :
    Inscription : Juin 2010
    Messages : 62
    Points : 24
    Points
    24
    Par défaut
    Bon j'ai encore besoin d'aide car j'ai bien réussi à spliter ma chaine (VARCHAR) mais le tri ne se fait toujours pas correctement je ne sais pas pourquoi :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    Select 
    id
    from questionnaires
    ORDER BY 
    SUBSTRING_INDEX( `id` , '.', 1 ),
    SUBSTRING_INDEX( SUBSTRING_INDEX( `id` , '.', 2 ), '.', -1 ),
    SUBSTRING_INDEX( SUBSTRING_INDEX( `id` , '.', 3 ), '.', -1 ),
    SUBSTRING_INDEX( SUBSTRING_INDEX( `id` , '.', 4 ), '.', -1 )
    J'ai donc essayé de convertir en INT

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    Select 
    id
    from questionnaire
    ORDER BY 
    CONVERT(INT,SUBSTRING_INDEX( `id` , '.', 1 )),
    CONVERT(INT,SUBSTRING_INDEX( SUBSTRING_INDEX( `id` , '.', 2 ), '.', -1 )),
    CONVERT(INT,SUBSTRING_INDEX( SUBSTRING_INDEX( `id` , '.', 3 ), '.', -1 )),
    CONVERT(INT,SUBSTRING_INDEX( SUBSTRING_INDEX( `id` , '.', 4 ), '.', -1 ))
    Mais j'ai une erreur de syntaxe SQL, j'ai essayé avec CAST mais ça ne fonctionne pas nom plus.

  5. #5
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    avant de tout mettre dans l'order by regardez ce que vous avez en sortie en mettant les transfo dans le select.


    Ca vous permettra d'avoir un minimum de visibilité sur ce que vous faites

  6. #6
    Membre à l'essai
    Inscrit en
    Juin 2010
    Messages
    62
    Détails du profil
    Informations forums :
    Inscription : Juin 2010
    Messages : 62
    Points : 24
    Points
    24
    Par défaut
    C'est ce que j'ai fait.
    Le résultat est ce que j'attends la chaine est splitter correctement.

    Mais si je fait un trie sur ces 4 chaines, l'ordre est toujours : 1, 10, 11, 2, 3 , 4 etc ...
    J'ai donc pensé que les chaines splitter devait être transformer en entier, je ne sais pas si je suis sur la bonne piste.

  7. #7
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    cf la doc : http://dev.mysql.com/doc/refman/5.6/...nction_convert

    choisissez le bon type pour le cast, ainsi que la bonne syntaxe

  8. #8
    Membre averti
    Profil pro
    Inscrit en
    Mai 2010
    Messages
    176
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2010
    Messages : 176
    Points : 301
    Points
    301
    Par défaut
    Bonjour,

    Le problème initial vient du non respect de la règle de modélisation des données relative à l'atomicité des données. Concrètement, cela signifie en SQL que la colonne contenant par exemple la valeur 1.10.1 aurait du être décomposée en 3 colonnes. Ainsi un simple ORDER BY 1, 2, 3; aurait réglé votre problème.

    Si vous pouvez remplacer la colonne qui pose problème par 3 colonnes, les soucis disparaitront. Mais bien sur, retoucher la modélisation des données a posteriori risque de poser des problèmes. Tous les traitements (notamment les requêtes SQL) qui accèdent à la colonne devront être corrigés. Si c'est simple pour votre cas, ce serait la solution. Si c'est compliqué et trop chronophage, il faudra "bidouiller" comme vous avez entrepris de le faire.

    Bon courage

  9. #9
    Membre à l'essai
    Inscrit en
    Juin 2010
    Messages
    62
    Détails du profil
    Informations forums :
    Inscription : Juin 2010
    Messages : 62
    Points : 24
    Points
    24
    Par défaut
    Effectivement la modélisation des données n'est pas optimum ... mais c'est indépendant de ma volonté malheureusement.
    J'ai donc continué dans ma réflexion et il s'avère que j'avais raison (pour le bidouillage) , avec la doc j'ai réussit à faire mon CAST correctement ce qui fait fonctionner mon trie correctement.

    Merci pour votre aide et conseils précieux.

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

Discussions similaires

  1. Pb de type de champs dans une requête
    Par djouahra.karim1 dans le forum Bases de données
    Réponses: 5
    Dernier message: 23/05/2005, 15h19
  2. [Struts][Conseil] type de champs ActionForm
    Par Sniper37 dans le forum Struts 1
    Réponses: 10
    Dernier message: 12/04/2005, 15h43
  3. Changement type de champ: ORA-01439
    Par PATMOR dans le forum Oracle
    Réponses: 8
    Dernier message: 12/02/2005, 16h14
  4. [Oracle][Delphi 7] Problème type de champ
    Par tiennos dans le forum Bases de données
    Réponses: 3
    Dernier message: 16/07/2004, 10h17
  5. [ADO] Constantes des types de champ
    Par SpaceFrog dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 05/09/2002, 11h08

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo