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 :

Compter sans doublon [Toutes versions]


Sujet :

Access

  1. #1
    Membre à l'essai
    Homme Profil pro
    Ingénieur qualité méthodes
    Inscrit en
    Août 2021
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : Maroc

    Informations professionnelles :
    Activité : Ingénieur qualité méthodes
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2021
    Messages : 19
    Points : 15
    Points
    15
    Par défaut Compter sans doublon
    Bonjour,

    dans un formulaire , j'affiche des enregistrements de la plus grande date du champ, qui parfois se répètent dans mon cas c'est le nombre de produit et le nombre de présentation et le nombre de lot.

    Je compte mes enregistrements dans une zone de texte, et j’ai utilisé cette expression et ça n’a pas marché :
    Pour le nombre de produit:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =CpteDom("Produit";"[SOMMEROMACO1]";"DATE = '" & MaxDom("DATE";"[SOMMEROMACO1]") & "'")
    Pour le nombre de présentation:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =CpteDom("Présentation";"[SOMMEROMACO1]";"DATE = '" & MaxDom("DATE";"[SOMMEROMACO1]") & "'")
    Pour le nombre de lot:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =CpteDom("Lot";"[SOMMEROMACO1]";"DATE = '" & MaxDom("DATE";"[SOMMEROMACO1]") & "'")
    Lorsque des enregistrements sont dupliqués, je voudrais qu'ils ne soient comptés qu'une seule fois.

    Nom : pipapap.JPG
Affichages : 69
Taille : 220,3 KoNom : sql.JPG
Affichages : 66
Taille : 36,5 KoNom : jgjgjg.JPG
Affichages : 63
Taille : 41,4 Ko

    Merci d'avance de vos idées.

  2. #2
    Expert éminent sénior
    Avatar de tee_grandbois
    Homme Profil pro
    retraité
    Inscrit en
    Novembre 2004
    Messages
    8 817
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Novembre 2004
    Messages : 8 817
    Points : 14 911
    Points
    14 911
    Par défaut
    bonjour,
    si tu veux continuer avec les fonctions de domaine, il va falloir créer 3 autres requêtes pour compter chaque colonne de manière unique:
    CPTEPRODUITS:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT Count(*) AS nbProduits FROM (SELECT DISTINCT produit FROM SOMMEROMACO1 where ok = Dmax("ok","SOMMEROMACO1")) AS TProd;
    CPTEPRESENTATIONS:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT Count(*) AS nbPresentations FROM (SELECT DISTINCT présentation FROM SOMMEROMACO1 where ok = Dmax("ok","SOMMEROMACO1")) AS TPres;
    CPETLOTS:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT Count(*) AS nbLots FROM (SELECT DISTINCT Lot FROM SOMMEROMACO1 where ok = Dmax("ok","SOMMEROMACO1")) AS TLot;
    ensuite, pour chaque zone de texte, chaque requête sera à utiliser avec la fonction PremDom (car chaque requête ne renvoie qu'un seul enregistrement) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    =PremDom("nbProduits";"CPTEPRODUITS")
    =PremDom("nbPresentations ";"CPTEPRESENTATIONS")
    =PremDom("nbLots";"CPTELOTS")

  3. #3
    Membre à l'essai
    Homme Profil pro
    Ingénieur qualité méthodes
    Inscrit en
    Août 2021
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : Maroc

    Informations professionnelles :
    Activité : Ingénieur qualité méthodes
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2021
    Messages : 19
    Points : 15
    Points
    15
    Par défaut
    Bonjour merci pour la réponse , juste une remarque le code que tu m'as envoyé il inclut aussi les champs vides lors du compte donc y' a t il une possibilité de ne pas inclure les champs vides dans le compte de nombre de produit/présentation/lot.

    Nom : pipapap.JPG
Affichages : 55
Taille : 331,4 Ko

    Merci encore pour tout ce que vous faites pour nous

  4. #4
    Expert éminent sénior
    Avatar de tee_grandbois
    Homme Profil pro
    retraité
    Inscrit en
    Novembre 2004
    Messages
    8 817
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Novembre 2004
    Messages : 8 817
    Points : 14 911
    Points
    14 911
    Par défaut
    il faut ajouter la condition and column1 is not null dans chaque sous-requête:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT Count(*) AS nbProduits FROM (SELECT DISTINCT produit FROM SOMMEROMACO1 where ok = Dmax("ok","SOMMEROMACO1") and produit is not null) AS TProd;

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

Discussions similaires

  1. Compter sans doublon avec condition
    Par Fayrouzam dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 08/06/2018, 12h15
  2. Compter sans doublons
    Par alexano211 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 08/09/2017, 14h16
  3. [XL-2010] Compter sans doublons des Noms + Prénoms
    Par Friberg59 dans le forum Excel
    Réponses: 17
    Dernier message: 01/11/2016, 16h25
  4. [AC-2003] Compter sans doublon
    Par minot83 dans le forum IHM
    Réponses: 4
    Dernier message: 05/07/2012, 16h28
  5. Compter sans doublons
    Par Beltegeuse dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 21/04/2008, 11h57

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