problème de jointure mysql : je m'en sors pas !!

Consultez la formation au référencement naturel Google de WebRankInfo / Ranking Metrics

pppplus
Nouveau WRInaute
 
Messages: 12
Inscription: Lun Oct 30, 2006 22:38

problème de jointure mysql : je m'en sors pas !!

Message le Lun Aoû 27, 2007 16:18

Je n'arrive pas à faire une requête avec une jointure, si quelqu'un peut m'aider... Car même en lisant tous les exemples sur le net, je ne m'en sors pas... 8O

Alors mes tables !

table1 =>cpa_cp_id, cpa_sitediff, actif
table2 =>visu_id_camp, visu_id (clé unique) + tous les autres champs
table3 =>cpa_cp_id (clé unique)

donc dans mes tables, les champs
table1.cpa_cp_id = table2.visu_id_camp = table3.cpa_cp_id


Je cherche à récupérer toutes les valeurs de la table 2, en vérifiant les choses suivantes :
- que le champ table2.visu_id = $id
- que le champ table1.cpa_sitediff = $diff existe, avec cpa_cp_id = visu_id de table2 et statut actif (=1 dans table1)

Donc pour l'instant, j'ai fait (j'ai pas mis * mais chaque champ !):

Code: Tout sélectionner
SELECT * FROM table2
LEFT JOIN table
ON table3.cpa_cp_id=table2.visu_id
WHERE visu_id='$id'


Mais je n'arrive pas à comprendre comment ajouter le reste (en espérant que mon début soit déjà bon...
Et j'espère que mon explication est à peu près compréhensible.. :wink:

Merci d'avance pour votre aide :!:

BigBook_
Nouveau WRInaute
 
Messages: 9
Inscription: Mar Aoû 28, 2007 11:04

Message le Mar Aoû 28, 2007 11:26

Et sans LEFT JOIN? Je sais que c'est moins propre, mais est-ce que ceci marche :

Code: Tout sélectionner
SELECT * FROM table1, table2, table3
WHERE table1.cpa_cp_id = table2.visu_id_camp
AND table2.visu_id_camp = table3.cpa_cp_id
AND table1.cpa_sitediff IS NOT NULL
AND table2.visu_id = '.$id.'
AND table1.cpa_sitediff = '.$diff.'
AND table1.actif = 1


EDIT : Pardon, j'ai lu un peu vite. Donc ce que tu as fonctionne, et c'est le reste des conditions qui te manquent?


arnaudmn
WRInaute accro
WRInaute accro
 
Messages: 1483
Inscription: Mer Mai 11, 2005 18:20

Re: problème de jointure mysql : je m'en sors pas !!

Message le Mar Aoû 28, 2007 11:40

[quote="pppplus"]
Je cherche à récupérer toutes les valeurs de la table 2, en vérifiant les choses suivantes :
- que le champ table2.visu_id = $id
- que le champ table1.cpa_sitediff = $diff existe, avec cpa_cp_id = visu_id de table2 et statut actif (=1 dans table1)

Code: Tout sélectionner
SELECT * FROM table2
LEFT JOIN table
ON table3.cpa_cp_id=table2.visu_id
WHERE visu_id='$id'


Déja, y'a un problème : tu peux pas mettre table3 dans le ON si la table n'est pas dans la jointure :-)

SELECT table2.*
from table2 inner join table1 on table1.cpa_cp_id = table2.visu_id_camp
where table2.visu_id=$id
and table1.cpa_sitediff = $diff
and table1.actif=1

Y'a pas besoin de jointure gauche si tu veux des lignes qui existent dans les 2 tables.

pppplus
Nouveau WRInaute
 
Messages: 12
Inscription: Lun Oct 30, 2006 22:38

Re: problème de jointure mysql : je m'en sors pas !!

Message le Mar Aoû 28, 2007 12:32

arnaudmn a écrit:
Déja, y'a un problème : tu peux pas mettre table3 dans le ON si la table n'est pas dans la jointure :-)



Oui erreur de frappe, c'était bien table3 !
Bon en me relisant en effet, je n'ai pas besoin de faire référence à cette table3 ! Et c'est bien plus simple avec 2 tables à lier, que 3...

Bon je relis vos propositions, je teste et je vous tiens au courant !

En tout cas merci !

pppplus
Nouveau WRInaute
 
Messages: 12
Inscription: Lun Oct 30, 2006 22:38

Message le Mar Aoû 28, 2007 13:40

Merci Arnaud, c'est apparemment parfait ta méthode !

Je me suis un peu perdu hier avec ma 3ème table... qui ne sert à rien !

J'ai encore du mal avec mes jointures...

BigBook, ça marche pas pour la tienne... mais merci tout de même !


Formation recommandée sur ce thème :

Formation Référencement naturel Google : apprenez une méthode efficace pour optimiser à fond le référencement naturel dans Google de façon durable... Formation animée par Olivier Duffez et Fabien Facériès, experts en référencement naturel.

Tous les détails sur le site Ranking Metrics : programme, prix, dates et lieux, inscription en ligne.

Lectures recommandées sur ce thème :



Qui est en ligne

Utilisateurs parcourant ce forum: Aucun utilisateur enregistré et 0 invités