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

Nouveau WRInaute
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:
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 :!:
 
Nouveau WRInaute
Et sans LEFT JOIN? Je sais que c'est moins propre, mais est-ce que ceci marche :

Code:
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?
 
WRInaute passionné
pppplus a dit:
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:
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.
 
Nouveau WRInaute
arnaudmn a dit:
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 !
 
Nouveau WRInaute
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 !
 
Discussions similaires
Haut