Précédent   Forum du club des développeurs et IT Pro > Bases de données > MySQL > Requêtes
Requêtes Forum d'entraide sur les requêtes MySQL
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse
 
Outils de la discussion
Publicité
'
Vieux 21/12/2012, 10h57   #1
pitav
Invité de passage
 
Homme Pascal Pivaty
Développeur Web
Inscription : avril 2012
Messages : 7
Détails du profil
Informations personnelles :
Nom : Homme Pascal Pivaty
Localisation : France, Eure (Haute Normandie)

Informations professionnelles :
Activité : Développeur Web

Informations forums :
Inscription : avril 2012
Messages : 7
Points : 1
Points : 1
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 :
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 :
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
pitav est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/12/2012, 11h53   #2
skuatamad
Expert Confirmé
 
Inscription : août 2008
Messages : 1 690
Détails du profil
Informations forums :
Inscription : août 2008
Messages : 1 690
Points : 2 812
Points : 2 812
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 :
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
skuatamad est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/12/2012, 13h23   #3
pitav
Invité de passage
 
Homme Pascal Pivaty
Développeur Web
Inscription : avril 2012
Messages : 7
Détails du profil
Informations personnelles :
Nom : Homme Pascal Pivaty
Localisation : France, Eure (Haute Normandie)

Informations professionnelles :
Activité : Développeur Web

Informations forums :
Inscription : avril 2012
Messages : 7
Points : 1
Points : 1
Merci skuatamad, mais j'avais trouvé une réponse qui fonctionne. Cependant, toutes les remarques sont le bien venues quand à ma solution.
Code :
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'
pitav est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse
Outils de la discussion

Navigation rapide


Fuseau horaire GMT +2. Il est actuellement 05h55.


 
 
 
 
Partenaires

Hébergement Web