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 :

Problème selection liste d'entiers dans un champ


Sujet :

Requêtes MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2013
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2013
    Messages : 2
    Par défaut Problème selection liste d'entiers dans un champ
    Bonjour,

    Je cherche à tester plusieurs types d'arborescence pour insérer une hiérarchie dans une base. Je suis actuellement en train de travailler sur l'arbre avec énumération de chemin et une requête me pose problème.

    Voici à quoi ressemble ma table FAMILLE :

    INT | VARCHAR | VARCHAR
    FAM_ID | PATH | FAM_LIB
    0 | -1 | Transport
    1 | 0 | Terrestre
    2 | 0,1 | Moto
    ...

    Je cherche a renvoyer tous les pères d'un nœud ou d'une feuille grâce à cette requête :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT * FROM `FAMILLE` WHERE FAM_ID IN
    			   (SELECT PATH FROM FAMILLE
                                            WHERE FAM_LIB = 'Moto')
    Mais au lieu de me rendre les deux parents, il me donne seulement la racine c'est à dire le premier qu'il voit...
    Si on donne a la place du deuxième SELECT 0,1 il rend bien les deux éléments.

    Voilà. Peut être que c'est un problème lors de la conversion des types.

  2. #2
    Membre prolifique Avatar de Artemus24
    Homme Profil pro
    Agent secret au service du président Ulysses S. Grant !
    Inscrit en
    Février 2011
    Messages
    6 883
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Agent secret au service du président Ulysses S. Grant !
    Secteur : Finance

    Informations forums :
    Inscription : Février 2011
    Messages : 6 883
    Par défaut
    Salut iceriku.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    --------------
    SET AUTOCOMMIT = 0
    --------------
     
    --------------
    START TRANSACTION
    --------------
     
    --------------
    DROP DATABASE IF EXISTS `base`
    --------------
     
    --------------
    CREATE DATABASE `base`
            DEFAULT CHARACTER SET `latin1`
            DEFAULT COLLATE       `latin1_general_ci`
    --------------
     
    --------------
    DROP TABLE IF EXISTS `famille`
    --------------
     
    --------------
    CREATE TABLE `famille`
    (
      `fam_id`    integer unsigned NOT NULL primary key,
      `path`      varchar(255)     NOT NULL,
      `fam_lib`   varchar(255)     NOT NULL
    ) ENGINE=InnoDB
      DEFAULT CHARSET=`latin1` COLLATE=`latin1_general_ci`
      ROW_FORMAT=COMPRESSED
    --------------
     
    --------------
    insert into `famille` (`fam_id`,`path`,`fam_lib`) values
      (0, '-1', 'transport'), (1, '0', 'terrestre'), (2, '0,1', 'moto')
    --------------
     
    --------------
    select * from famille
    --------------
     
    +--------+------+-----------+
    | fam_id | path | fam_lib   |
    +--------+------+-----------+
    |      0 | -1   | transport |
    |      1 | 0    | terrestre |
    |      2 | 0,1  | moto      |
    +--------+------+-----------+
    --------------
    SELECT * FROM `FAMILLE`
    WHERE find_in_set(fam_id,(select path from famille where fam_lib='moto')) != 0
    --------------
     
    +--------+------+-----------+
    | fam_id | path | fam_lib   |
    +--------+------+-----------+
    |      0 | -1   | transport |
    |      1 | 0    | terrestre |
    +--------+------+-----------+
    --------------
    commit
    --------------
     
    --------------
    SET AUTOCOMMIT = 1
    --------------
     
    Appuyez sur une touche pour continuer...
    @+

Discussions similaires

  1. [CSV] liste de résultats dans un champ
    Par lodan dans le forum Langage
    Réponses: 4
    Dernier message: 15/07/2006, 18h25
  2. Probléme pour insérer une variable dans un champs
    Par BOUTRAIS dans le forum Access
    Réponses: 2
    Dernier message: 11/04/2006, 22h45
  3. [MySQL] Problème d'affichage d'enregistrement dans un champs
    Par mosca_coroneja dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 06/04/2006, 11h19
  4. Réponses: 4
    Dernier message: 09/02/2006, 15h20
  5. Plusieurs liste de choix dans 1 champs
    Par tek34 dans le forum IHM
    Réponses: 8
    Dernier message: 24/11/2005, 11h43

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