Précédent   Forum des professionnels en informatique > Bases de données > MySQL > Outils
Outils Forum d'entraide sur les outils pour MySQL. Avant de poster -> Outils 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 10/08/2007, 19h27   #1
Futur Membre du Club
 
Inscription : avril 2007
Messages : 38
Détails du profil
Informations forums :
Inscription : avril 2007
Messages : 38
Points : 15
Points : 15
Par défaut Problème avec LEFT JOIN

Bonjour cela fait une dizaine de jours que je cherche à résoudre ce problème.
J'ai une requete qui ne donne plus le meme résultat depuis que je suis passé en version 5 de Mysql.
J'ai 2 tables : "articles" & "equivalences", dans la table "equivalences" j'ai de 0 à n enregistrements pour un article de la table "articles"

le code suivant me pose probleme :

Code :
1
2
3
4
5
6
7
8
9
10
 
SELECT t1.artno, t1.artlib, t1.tarif, TRUNCATE(t1.qtstk,0) AS qtstk, 
           t2.artno    AS artno2, t2.artlib AS artlib2, t2.tarif AS tarif2, 
           TRUNCATE(t2.qtstk,0) AS qtstk2
FROM    articles AS t1
LEFT JOIN equivalences AS t3 ON (t1.stgrp=t3.stgrp AND t1.stdos=
              t3.stdos AND t1.artno=t3.artno)
LEFT JOIN articles AS t2 ON (t2.stgrp=t3.stgrp AND t2.stdos=t3.stdos AND 
              t2.artno=adpart)
WHERE t1.stgrp= 1 AND t1.stdos= 50 AND t1.stkmag='000001' AND t2.stkmag='000001'
je n'obtiens pas les enregs null, c'est a dire ceux qui n'ont pas de correspndance dans la table "articles".
Si je ne fais que la première jonction j'ai les enregs avec "null" quand il n'y a pas de correspondance. Mais dès que je rajoute le 2nd LEFT JOINT je n'obtient pas le résultat souhaité.J'ai fais dans PhpMyAdmin l'option EXPLAIN et je constate que l'optimiseur de requette utilise la table "articles" puis la table "equivalences" quand je n'ai qu'une jonction. Mais dans le cas des deux jonctions il utilise d'abord la table "equivalences" puis la tables ("articles" t2) et enfin la table ("articles" t1)
Jai donc tenter de l'obliger à utiliser la table (t1 "articles") avec STRAIGHT_JOIN et en faisant toutes sortes de combinaisons sans succès toujours le meme resultat.
Le résultat que je recherche c'est avoir tous les enregs de la table (t1 "articles") dont cetains n fois (n=nombre d'équivalences) et avoir "null" pour les champs de de t2 quand il n'y a pas d'équivalences.
J'espère avoir été assez clair. Merci de vos suggestions.
okilele est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 10/08/2007, 19h57   #2
Rédacteur/Modérateur

 
Avatar de Antoun
 
Homme Antoine Dinimant
Consultant en Business Intelligence
Inscription : octobre 2006
Messages : 5 854
Détails du profil
Informations personnelles :
Nom : Homme Antoine Dinimant
Âge : 42
Localisation : France, Paris (Île de France)

Informations professionnelles :
Activité : Consultant en Business Intelligence
Secteur : Conseil

Informations forums :
Inscription : octobre 2006
Messages : 5 854
Points : 9 540
Points : 9 540
Code :
WHERE ... AND (t2.stkmag='000001' OR t2.stkmag IS NULL)
__________________
Antoun
Expert SQL, BO, Essbase

La bible d'Essbase est parue !
Antoun est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/08/2007, 12h55   #3
Futur Membre du Club
 
Inscription : avril 2007
Messages : 38
Détails du profil
Informations forums :
Inscription : avril 2007
Messages : 38
Points : 15
Points : 15
merci beaucoup !!!!!!
okilele 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 23h24.


 
 
 
 
Partenaires

Hébergement Web