Précédent   Forum des professionnels en informatique > Logiciels > Microsoft Office > Access > Requêtes et SQL.
Requêtes et SQL. Tout ce qui concerne vos questions sur les requêtes et le SQL sous Access se trouve ici.
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 15/03/2011, 15h17   #1
Nouveau Membre du Club
 
Inscription : novembre 2008
Messages : 43
Détails du profil
Informations forums :
Inscription : novembre 2008
Messages : 43
Points : 26
Points : 26
Par défaut [JOINTURES] Condition de jointure avec plusieurs tables

Bonjour bonjour,

J'ai un petit souci sur une requête SQL quand je veux imbriquer deux joins pour sélectionner des données provenant de trois table :

Code :
1
2
3
4
5
 
SELECT *
FROM 
(T1 INNER JOIN T2 ON (T1.C1 = T2.C1))
INNER JOIN T3 ON (T3.C2 = T2.C1 AND T3.C3 = T1.C1)
Access refuse tout simplement cette jointure avec le message "Expression JOIN non supportée".

Y'aurait-il donc une âme charitable pour m'expliquer pourquoi ce n'est "pas supporté", et éventuellement, comment contourner ce souci ?

Merci d'avance et bonne aprem à tous
mistertbo est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/03/2011, 16h39   #2
Membre chevronné
 
Avatar de alassanediakite
 
Homme Alassane Diakité
Conseil - Consultant en systèmes d'information
Inscription : août 2006
Messages : 539
Détails du profil
Informations personnelles :
Nom : Homme Alassane Diakité
Âge : 34
Localisation : Mali

Informations professionnelles :
Activité : Conseil - Consultant en systèmes d'information

Informations forums :
Inscription : août 2006
Messages : 539
Points : 604
Points : 604
Envoyer un message via Yahoo à alassanediakite
salut
supposons que T1 est liée à T2 par C1 et le même T1 est liée à T3 par C2, la requête doit être:
Code :
1
2
3
4
5
 
SELECT *
FROM 
(T1 INNER JOIN T2 ON (T1.C1 = T2.C1))
INNER JOIN T3 ON (T3.C2 = T1.C2)
Mais s'il y a une jointure en cycle, il te faudra trois requêtes: la 1ère sur T1 et T2, la 2ème Sur T1 et T3 puis la 3ème sur les deux premières.
@+
__________________
Le monde est trop bien programmé pour être l’œuvre du hasard…
alassanediakite est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/03/2011, 14h56   #3
Nouveau Membre du Club
 
Inscription : novembre 2008
Messages : 43
Détails du profil
Informations forums :
Inscription : novembre 2008
Messages : 43
Points : 26
Points : 26
Erf je me suis trompé dans la requête, sur le deuxième join :

Code :
1
2
3
4
5
SELECT *
FROM 
(T1 INNER JOIN T2 ON (T1.C1 = T2.C1))
INNER JOIN T3 ON (T3.C2 = T2.C2 AND T3.C3 = T1.C3)
Mais en gros, si j'ai bien compris, ça ne change rien... il faut que j'utilise trois requêtes ?

Merci pour votre réponse et bonne après midi
mistertbo est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/03/2011, 23h17   #4
Expert Confirmé Sénior
 
Avatar de f-leb
 
Homme Fabien
Enseignant
Inscription : janvier 2009
Messages : 2 410
Détails du profil
Informations personnelles :
Nom : Homme Fabien
Âge : 41
Localisation : France, Sarthe (Pays de la Loire)

Informations professionnelles :
Activité : Enseignant

Informations forums :
Inscription : janvier 2009
Messages : 2 410
Points : 4 439
Points : 4 439
bonsoir,

essayer en cassant le cycle, c.a.d au lieu de faire les jointures:
Code :
1
2
3
4
T1-------T2-------T3
|                  |
+------------------+
faire:
Code :
1
2
T1-------T2-------T3------T1_1
où T1_1 est un alias de T1
f-leb est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/03/2011, 11h45   #5
Membre chevronné
 
Avatar de alassanediakite
 
Homme Alassane Diakité
Conseil - Consultant en systèmes d'information
Inscription : août 2006
Messages : 539
Détails du profil
Informations personnelles :
Nom : Homme Alassane Diakité
Âge : 34
Localisation : Mali

Informations professionnelles :
Activité : Conseil - Consultant en systèmes d'information

Informations forums :
Inscription : août 2006
Messages : 539
Points : 604
Points : 604
Envoyer un message via Yahoo à alassanediakite
Très astucieux (plus court, plus rapide).
__________________
Le monde est trop bien programmé pour être l’œuvre du hasard…
alassanediakite est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 21h27.


 
 
 
 
Partenaires

Hébergement Web