IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Access Discussion :

Afficher les enregistrements d'une table non présents dans une requête [AC-2010]


Sujet :

Access

  1. #1
    Candidat au Club
    Homme Profil pro
    Consultant ERP
    Inscrit en
    Avril 2015
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Consultant ERP

    Informations forums :
    Inscription : Avril 2015
    Messages : 8
    Points : 4
    Points
    4
    Par défaut Afficher les enregistrements d'une table non présents dans une requête
    Bonjour,

    Je précise que pour effectuer mes requêtes, j'utilise l'assistant de requête.

    J'ai 2 tables :

    Produit (ID_produit, Libelle, Prix)
    Date_vente (Num_Date, Date_vente, #Num_produit)

    J'aimerai connaitre les produits qui n'ont pas été vendus le mois dernier.

    Pour cela j'ai effectué une requête qui liste les produits vendus le mois dernier avec dans la partie "critères" :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     Année(Date())*12+PartDate("m";Date())-1

    Maintenant je tente de construire une autre requête, qui comparer cette liste avec ma table "PRODUIT" pour afficher les produits non présents.
    J'ai testé avec "NOT, NOT EXISTS et <>".

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    NOT ([Mois_precedent].[IDUtilisateur])
    Je pense que le problème vient de la syntaxe.

    Merci pour votre aide

  2. #2
    Membre éclairé
    Avatar de Didier L
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juillet 2004
    Messages
    503
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juillet 2004
    Messages : 503
    Points : 806
    Points
    806
    Par défaut
    Bonjour,

    Ta seconde requête est basé sur ta table et ta requête avec une jointure, ou est-ce qu'elle n'est basé que sur ta table produit et tu veux mettre un critère de sélection basé sur la liste obtenue dans ta première requête ?

    Car tu as deux possibilités pour faire ce que tu veux ;-)

    Peux tu nous montrer les syntaxes complètes de tes deux requêtes ?
    @+


    Pensez au tag

  3. #3
    Candidat au Club
    Homme Profil pro
    Consultant ERP
    Inscrit en
    Avril 2015
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Consultant ERP

    Informations forums :
    Inscription : Avril 2015
    Messages : 8
    Points : 4
    Points
    4
    Par défaut
    Bonjour,

    Voici les requêtes générées par l'assistant de requête :


    Requête : "Mois_precedent"

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT DISTINCT PRODUIT.ID_produit, PRODUIT.Libelle
    FROM DATE_VENTE INNER JOIN PRODUIT ON DATE_VENTE.Num_Produit = PRODUIT.ID_produit
    WHERE (((Year([Date_vente])*12+DatePart("m",[Date_vente]))=Year(Date())*12+DatePart("m",Date())-1));

    Requête : Produits non présents dans la requête précédente. Je n'arrive pas à utiliser le "NOT".

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT DISTINCT PRODUIT.ID_produit, PRODUIT.Libelle
    FROM PRODUIT INNER JOIN Mois_precedent ON PRODUIT.ID_produit = Mois_precedent.ID_produit
    WHERE ((Not (PRODUIT.ID_produit)=([Mois_precedent].[ID_produit])));
    Merci

  4. #4
    Membre éclairé
    Avatar de Didier L
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juillet 2004
    Messages
    503
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juillet 2004
    Messages : 503
    Points : 806
    Points
    806
    Par défaut
    Merci

    Très bien.
    En fait avec l'assistant requête, tu dois cliquer sur la relation entre la table PRODUITS et la requête Mois_Precedent afin de modifier le sens de la jointure.
    la relation de base est basée sur l'égalité des champs ID_produit.
    Dans les deux autres choix proposés, sélectionne "afficher tous les enregistrement de la table produits et uniquement ceux de la table Mois_Précedent pour lesquels les champs joint sont égaux.
    Ainsi tu verra apparaître tous tes produits.
    Si tu fais afficher la colonne ID_produit de la requête Mois_precedent, tu verra que sur certaine ligne il n'y a pas de valeur.
    Donc dans ton critère de sélection, tu mettra "est null" pour cette colonne. et ainsi q tu n'aura que les produits qui n'ont pas de correspondance dans la requête Mois_precedent

    Tu devrais avoir une syntaxe SQL du style
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT DISTINCT PRODUIT.ID_produit, PRODUIT.Libelle
    FROM PRODUIT LEFT JOIN Mois_precedent ON PRODUIT.ID_produit = Mois_precedent.ID_produit
    WHERE [Mois_precedent].[ID_produit] Is null;
    @+


    Pensez au tag

  5. #5
    Candidat au Club
    Homme Profil pro
    Consultant ERP
    Inscrit en
    Avril 2015
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Consultant ERP

    Informations forums :
    Inscription : Avril 2015
    Messages : 8
    Points : 4
    Points
    4
    Par défaut
    Bonjour,

    Merci beaucoup pour votre aide et vos explications. Cela fonctionne très bien.
    Vos conseils me serviront pour mes prochaines requêtes.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 2
    Dernier message: 02/04/2012, 08h34
  2. [AC-2003] enregistrements ajoutés dans une table en double dans la requête
    Par alainmante dans le forum IHM
    Réponses: 4
    Dernier message: 13/04/2009, 14h04
  3. Réponses: 5
    Dernier message: 18/03/2009, 19h31
  4. Recherche d'une valeur présent dans une table mais pas dans une autre
    Par bossLINDROS dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 19/06/2008, 15h12
  5. Réponses: 1
    Dernier message: 12/04/2007, 17h08

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo