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

IHM Discussion :

limiter la liste déroulante client aux seuls clients n'ayant pas encore effectué de commande cette année [AC-2007]


Sujet :

IHM

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 10
    Points : 7
    Points
    7
    Par défaut limiter la liste déroulante client aux seuls clients n'ayant pas encore effectué de commande cette année
    Bonjour.

    J'ai 2 tables Client et commande. Chaque client ne peut effectuer qu'une commande par an. J'ai donc créer un index dans la table commande entre le Client et l'année en cours.

    Je souhaite maintenant créer un formulaire de nouvelle commande ou n'apparaisse dans la liste déroulante que les clients n'ayant pas encore effectué de commande cette année.

    Il faut donc que je modifie ma liste déroulante dans ma table commande. J'ai essayé de rajouté un critère du style:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT Client.N°, Client.Nom, Client.Prénom, Client.contact
    FROM Client
    WHERE (((Client.N°)<>[commande].[client]));

    Mais le problème c'est que je ne peux pas effectuer une requête sur ma table commande dans ma table commande.

    Avez vous une idée pour limiter la liste déroulante aux seuls clients n'ayant pas encore effectué de commande cette année?


    Merci beaucoup

  2. #2
    Expert confirmé Avatar de nico84
    Homme Profil pro
    Consultant/développeur ERP
    Inscrit en
    Mai 2008
    Messages
    3 108
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant/développeur ERP
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2008
    Messages : 3 108
    Points : 5 231
    Points
    5 231
    Par défaut
    Bonjour,

    Je pense qu'une condition
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    where not exists (select ... from commande where ...)
    devrait faire l'affaire

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 10
    Points : 7
    Points
    7
    Par défaut
    Merci beaucoup pour ton aide.

    J'ai finalement résuii à obtenir ce que je souhaitais avec la formule généré en partie par access:

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT Client.N°, Client.Nom, Client.Prénom
    FROM Client
    WHERE (((Exists (SELECT Commande.Client FROM Commande WHERE Commande.Client=Client.N° ))<>True))
    ORDER BY Client.Nom, Client.Prénom;

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 26/07/2013, 08h31
  2. Réponses: 0
    Dernier message: 13/10/2011, 11h15
  3. [AC-2003] Limiter une liste déroulante d'un formulaire selon le filtre appliqué
    Par sigcl05 dans le forum VBA Access
    Réponses: 0
    Dernier message: 27/11/2009, 14h59
  4. Concaténer deux liste déroulante en une seule
    Par jules_diedhiou dans le forum Langage
    Réponses: 8
    Dernier message: 12/05/2009, 14h45
  5. Liste des clients pouvant encore effectuer des commandes
    Par julie75 dans le forum Langage SQL
    Réponses: 13
    Dernier message: 04/07/2007, 15h49

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