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 31/12/2010, 11h00   #1
Membre actif
 
Inscription : décembre 2009
Messages : 204
Détails du profil
Informations forums :
Inscription : décembre 2009
Messages : 204
Points : 186
Points : 186
Par défaut Alternative à Except

Bonjour à tous,

Je dispose de 2 tables :
(La normalisation laisse à désirer mais je dois m'y adapter)

Activites (ID,DateAct,PersonnelAct)
Travaux (DateT,PersonnelT)

Je souhaite rechercher quels enregistrements (Champs Date et Personnel) de la Table Travaux ne sont pas dans la table Activites.

J'ai réalisé la requête suivante :

Code :
1
2
3
4
5
SELECT DateAct as D, PersonnelAct as P FROM Activites
 
EXCEPT [MINUS]
 
SELECT DateT as D, PersonnelT as P FROM Travaux
Bien entendu, ni except ni minus ne sont pris en compte par access. J'avais pensé à l'opérateur NOT IN mais est-ce réalisable sur 2 champs?

Comment puis-je réalisé ma requête ?

Merci de bien vouloir me venir en aide.
tarnx est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 31/12/2010, 11h31   #2
Expert Confirmé
 
Avatar de Richard_35
 
Homme
Inscription : juillet 2007
Messages : 2 176
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France, Ille et Vilaine (Bretagne)

Informations forums :
Inscription : juillet 2007
Messages : 2 176
Points : 2 805
Points : 2 805
Bonjour Tarnx,

Eh bien, via l'assistant, c'est tout simple...

En création de requête, choisis "Requête de non correspondance" et tu suis ce que te demande Access.

Re-postes, si tu n'y arrives pas.
__________________
Dis-nous et à bientôt,
Richard.
----------------------------------------------------------------------------------------------
En cas de résolution, et afin de faciliter la tâche des bénévoles, merci de cliquer sur .
et permettent aux forumeurs de cibler leur recherche dans une discussion : n'hésitez pas à voter !
Richard_35 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 31/12/2010, 15h03   #3
Membre actif
 
Inscription : décembre 2009
Messages : 204
Détails du profil
Informations forums :
Inscription : décembre 2009
Messages : 204
Points : 186
Points : 186
En cherchant l'utilitaire "Requête de non correspondance" (que je n'ai pas trouvé ) , j'ai réussi à écrire ma requête.

Code :
1
2
3
4
5
SELECT * FROM Activites
WHERE ID Not In (
     SELECT ID
     FROM Activites A INNER JOIN Travaux T ON (T.DateT = A.DateAct) AND (T.PersonnelT = A.PersonnelAct)
);
Je ne connaissais pas le 'And' dans un 'Inner Join', maintenant c'est le cas.

Merci du coup de pouce
tarnx est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 31/12/2010, 16h20   #4
Expert Confirmé
 
Avatar de Richard_35
 
Homme
Inscription : juillet 2007
Messages : 2 176
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France, Ille et Vilaine (Bretagne)

Informations forums :
Inscription : juillet 2007
Messages : 2 176
Points : 2 805
Points : 2 805
Dans l'onglet "Requête", "Nouveau" : dans la liste apparaît "Assistant requête de non correspondance", "OK"... puis tu suis ce que Access te demande.
__________________
Dis-nous et à bientôt,
Richard.
----------------------------------------------------------------------------------------------
En cas de résolution, et afin de faciliter la tâche des bénévoles, merci de cliquer sur .
et permettent aux forumeurs de cibler leur recherche dans une discussion : n'hésitez pas à voter !
Richard_35 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 16h02.


 
 
 
 
Partenaires

Hébergement Web