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 :

Jointure et résultats multiples


Sujet :

Requêtes MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Futur Membre du Club
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juillet 2014
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juillet 2014
    Messages : 3
    Par défaut Jointure et résultats multiples
    Bonjour,

    D'abord, merci pour l'intérêt que vous portez à mon post.
    Alors, j'ai cette requête :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    SELECT p.ID, p.post_type, p.name, p.content, p.date, p.parent, p.state, p.o,
    	   mv.post_ID, mv.meta_key, mv.meta_value 
    FROM post p
    LEFT JOIN post_meta_value mv ON  mv.post_ID = p.ID
    Le problème c'est que un "post" peut avoir plusieurs "meta_value", et actuellement je ne récupère qu'une entrée de la table post_meta_value par "post", ex :

    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
    Array
    (
        [ID] => 33
        [post_type] => 3
        [name] => ai03
        [content] => 
        [date] => 0000-00-00 00:00:00
        [parent] => 1
        [state] => 0
        [o] => 0
        [post_ID] => 33
        [meta_key] => article_images
        [meta_value] => [{"ID":"34"}]
    )
    Je cherche donc un moyen en SQL de récupérer plusieurs meta_key / meta_value par entrée dans la table post.

    C'est possible ? Je deviens dingue

    Merci d'avance

  2. #2
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 065
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 065
    Par défaut
    Oui, c'est possible, mais il faut faire plusieurs jointures (à gauche) sur la table post_meta_value, en mettant une meta_key différente par jointure.
    Rédacteur / Modérateur SGBD et R
    Mes tutoriels et la FAQ MySQL

    ----------------------------------------------------
    Pensez aux balises code et au tag
    Une réponse vous a plu ? N'hésitez pas à y mettre un
    Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juillet 2014
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juillet 2014
    Messages : 3
    Par défaut
    Merci beaucoup !
    Du coup je fais cette requête :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT mv.post_ID, mv.meta_key, mv.meta_value, p.ID, p.post_type, p.name, p.content, p.date, p.parent, p.state, p.o  FROM post_meta_value mv JOIN post p ON  mv.post_ID = p.ID
    Mais du coup, dans mon tableau de sortie, pour chaque "post", je récupère autant d'éléments qu'il a de "meta_value" ex :

    Code php : 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
     
    Array (
    ...
    )
     
    Array
    (
        [post_ID] => 31
        [meta_key] => description
        [meta_value] => az
        [ID] => 31
        [post_type] => 3
        [name] => ai02
        [content] => 
        [date] => 0000-00-00 00:00:00
        [parent] => 1
        [state] => 0
        [o] => 128
    )
     
    Array
    (
        [post_ID] => 31
        [meta_key] => article_images
        [meta_value] => []
        [ID] => 31
        [post_type] => 3
        [name] => ai02
        [content] => 
        [date] => 0000-00-00 00:00:00
        [parent] => 1
        [state] => 0
        [o] => 128
    )
     
    Array (
    ...
    )

    Ce que je veux en sortie, c'est une seule entrée par "post" sous cette forme :

    Code php : 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
    Array (
    ...
    )
    
    Array
    (
        [post_ID] => 31
        [article_images] => []
        [description] => az
        [ID] => 31
        [post_type] => 3
        [name] => ai02
        [content] => 
        [date] => 0000-00-00 00:00:00
        [parent] => 1
        [state] => 0
        [o] => 128
    )
    
    Array (
    ...
    )

    Du coup, je fais ça actuellement :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    while ($element = $reponse->fetch(PDO::FETCH_ASSOC))
    {
         $test_tab[$element['ID']][$element['meta_key']] = $element['meta_value'];
         unset($element['meta_key']);
         unset($element['meta_value']);
         $this->list[$element['ID']] = $element;
    }
     
    foreach ($this->list as $key => $value) {
         foreach ($test_tab[$key] as $k => $v) {
              $this->list[$key][$k] = $v;
         }
    }
    Et ça fonctionne. Pensez-vous que c'est la "bonne" méthode ?

    Merci encore !

Discussions similaires

  1. Jointure aux résultats multiples
    Par samspitz dans le forum Zend_Db
    Réponses: 1
    Dernier message: 24/06/2010, 18h11
  2. Recherchev poussée avec résultats multiples
    Par solorac dans le forum Excel
    Réponses: 13
    Dernier message: 22/06/2007, 11h14
  3. Jointure sur résultat de procédure
    Par ben-34 dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 23/02/2007, 13h58
  4. [SQL] Recherche à résultats multiples SQL - PHP
    Par Paradise01 dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 15/08/2006, 14h52
  5. selection simple mais résultat multiple dans combobox
    Par forzaxelah dans le forum Bases de données
    Réponses: 1
    Dernier message: 12/06/2006, 14h21

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