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 :

Aide pour finir ma requête


Sujet :

Requêtes MySQL

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Développeur
    Inscrit en
    Avril 2012
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Eure (Haute Normandie)

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Avril 2012
    Messages : 9
    Points : 7
    Points
    7
    Par défaut Aide pour finir ma requête
    Bonjour

    J'ai une requête sur deux tables wp_posts et wp_postmeta qui fonctionne presque comme je veux.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    SELECT
    wp_posts.ID AS ID,
    wp_posts.post_title AS nom,
    wp_postmeta.meta_value
     
    FROM wp_posts
    LEFT JOIN wp_postmeta ON (ID = wp_postmeta.post_id)
     
    WHERE wp_posts.post_type = 'praticien'
    AND wp_postmeta.meta_key = 'prenom'
    OR wp_postmeta.meta_key = 'adresse'
    OR wp_postmeta.meta_key = 'ville'
    La requête me retourne pour chaque ID les trois lignes suivantes par exemple pour l'ID 117
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    ID= "117",  nom="Fayard Jacquin",  meta_value="Laurence"
    ID= "117",  nom="Fayard Jacquin",  meta_value="4, avenue du Parc"
    ID= "117",  nom="Fayard Jacquin",  meta_value="Paris"


    Ce que j'aimerais faire, c'est d'avoir une seule ligne de retour par ID et de pouvoir donner un nom différend à chaque meta_value (prenom, adresse et ville) dans la ligne de retour.

    Merci de votre aide

  2. #2
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 947
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 947
    Points : 5 846
    Points
    5 846
    Par défaut
    Déjà la jointure externe n'est pas correcte, donc soit utiliser une jointure interne soit il faut remonter les filtres dans la condition de jointure.
    Ensuite c'est un peu de la cosmétique, mais avec GROUP_CONCAT c'est plutôt simple, qu'est ce que ça donne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT p.ID AS ID,
           p.post_title AS nom,
           group_concat(concat(m.meta_key, ' = ', m.meta_value) ORDER BY meta_key SEPARATOR ',') as gr_meta_value 
      FROM wp_posts p
      LEFT JOIN wp_postmeta m ON m.ID = p.post_id 
                             AND (m.meta_key = 'prenom' OR m.meta_key = 'adresse' OR m.meta_key = 'ville') 
     WHERE p.post_type = 'praticien'
     group by p.ID, p.post_title

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Développeur
    Inscrit en
    Avril 2012
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Eure (Haute Normandie)

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Avril 2012
    Messages : 9
    Points : 7
    Points
    7
    Par défaut
    Merci skuatamad, mais j'avais trouvé une réponse qui fonctionne. Cependant, toutes les remarques sont le bien venues quand à ma solution.
    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
    SELECT
    wp_posts.ID AS ID,
    wp_posts.post_title AS nom,
    wp_postmeta.meta_value AS prenom,
    m1.meta_value AS adresse,
    m2.meta_value AS ville
     
    FROM wp_posts
    LEFT JOIN wp_postmeta ON (ID = wp_postmeta.post_id)
    LEFT JOIN wp_postmeta AS m1 ON (ID = m1.post_id)
    LEFT JOIN wp_postmeta AS m2 ON (ID = m2.post_id)
     
    WHERE wp_posts.post_type = 'praticien'
    AND wp_postmeta.meta_key = 'prenom'
    AND m1.meta_key = 'adresse'
    AND m2.meta_key = 'ville'

Discussions similaires

  1. besoin d 'aide pour formuler une requête
    Par cdu dans le forum Langage SQL
    Réponses: 2
    Dernier message: 08/04/2006, 19h38
  2. besoin d'aide pour optimiser une requête
    Par jisse dans le forum Langage SQL
    Réponses: 4
    Dernier message: 27/01/2006, 09h41
  3. [Access 2000] Aide pour finir une requête
    Par Tankian dans le forum Access
    Réponses: 4
    Dernier message: 21/12/2005, 19h53
  4. Aide pour écrire une requête complexe
    Par julienbdx dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 29/11/2005, 16h58
  5. [TPW][cours]Demande d'aide pour finir un programme
    Par jf dans le forum Turbo Pascal
    Réponses: 21
    Dernier message: 16/06/2003, 18h10

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