Précédent   Forum des professionnels en informatique > 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 Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 07/01/2011, 09h07   #1
Invité de passage
 
Inscription : février 2010
Messages : 5
Détails du profil
Informations forums :
Inscription : février 2010
Messages : 5
Points : 2
Points : 2
Par défaut Créer des colonnes à partir de clé-valeurs

Bonjour,

Je cherche le moyen le plus efficace pour résoudre le problème suivant ...

J'ai une table de meta données (Wordpress) organisée comme suit:

Code :
1
2
3
4
5
6
post_id             meta_key           meta_value
----------------------------------------------
1                     _latitude            11.2222
1                     _longitude          22.3333
2                     _latitude            33.4444
2                     _longitude          55.6666
Générique mais pas pratique pour faire des requêtes (en tout cas c'est mon impression)

Je voudrais pouvoir créer une table organisée comme suit:

Code :
1
2
3
4
post_id        latitude          longitude
----------------------------------------------
1                11.2222         22.3333
2                33.4444         55.6666
Y a t'il une méthode (SQL) plus simple et plus efficace qu'une boucle dans un bout de code ?

Merci

Cdt
adder est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/01/2011, 09h18   #2
ced
Rédacteur/Modérateur

 
Avatar de ced
 
Homme Cédric Duprez
Inscription : avril 2002
Messages : 3 823
Détails du profil
Informations personnelles :
Nom : Homme Cédric Duprez
Âge : 36
Localisation : France, Loiret (Centre)

Informations professionnelles :
Secteur : Agroalimentaire - Agriculture

Informations forums :
Inscription : avril 2002
Messages : 3 823
Points : 6 441
Points : 6 441
Bonjour,

Oui, tu peux passer par des jointures.
Mais il te faudra autant de jointures que de mots clé.
Dans le cas de ton exemple, la requête qui donne ce résultat est :
Code :
1
2
3
4
5
6
SELECT t1.post_id, t1.meta_value AS latitude, t2.meta_value AS longitude
FROM ta_table t1
INNER JOIN ta_table t2 ON t1.post_id = t2.post_id
WHERE t1.meta_key = '_latitude'
AND t2.meta_key = '_longitude'
ORDER BY t1.post_id;
ced
__________________
Rédacteur / Modérateur SGBD
Mes tutoriels et la FAQ MySQL

----------------------------------------------------
Pensez aux balises code et au tag
Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça
ced est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/01/2011, 10h13   #3
Invité de passage
 
Inscription : février 2010
Messages : 5
Détails du profil
Informations forums :
Inscription : février 2010
Messages : 5
Points : 2
Points : 2
MERCI !

Ca fait exactement ce que je veux ...
adder est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 17h32.


 
 
 
 
Partenaires

Hébergement Web