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

Requêtes et SQL. Discussion :

Requête Count et DISTINCT


Sujet :

Requêtes et SQL.

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2009
    Messages
    73
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2009
    Messages : 73
    Points : 48
    Points
    48
    Par défaut Requête Count et DISTINCT
    Bonsoir à tous j'ai un module avec une requête en Count pour afficher la valeur dans une zone de texte, jusque ici pas de problème la valeur s'affiche correctement dans la zone de texte. Je viens de voir que j'ai des doublons donc j'ai essayé de mettre un DISTINCT mais ça ne marche pas

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    Function Sco_lex_hiver(Annee As Long)
    Dim Rst As DAO.Recordset
    Dim Db As DAO.Database
    Dim Source As String
    Set Db = CurrentDb
    
    Source = "SELECT Count(DISTINCT INSCRITS.Num_enfant)FROM INSCRITS, SEMAINES, ENFANTS WHERE ENFANTS.Num_enfant = INSCRITS.Num_enfant AND INSCRITS.Num_semaine=SEMAINES.Num_semaine And Scolarise_lexy = True And SEMAINES.Nom IN ('H-1','H-2')  And SEMAINES.Annee= " & Annee & ";"
    Set Rst = Db.OpenRecordset(Source, dbOpenDynaset)
    
    Sco_lex_hiver = Rst.Fields(0)
    
    Rst.Close
    Db.Close
    Set Rst = Nothing
    Set Db = Nothing
    
    End Function
    Erreur syntaxe opérateur absent dans l'expression (...)

  2. #2
    Expert éminent
    Avatar de LedZeppII
    Homme Profil pro
    Maintenance données produits
    Inscrit en
    Décembre 2005
    Messages
    4 485
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Maintenance données produits
    Secteur : Distribution

    Informations forums :
    Inscription : Décembre 2005
    Messages : 4 485
    Points : 7 759
    Points
    7 759
    Par défaut
    Bonsoir,

    Effectivement, DISTINCT n'est accepté qu'immédiatement derrière SELECT.

    Transforme ta requête en requête SELECT DISTINCT et compte le nombre d'enregistrements retournés :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Source = "SELECT DISTINCT INSCRITS.Num_enfant FROM INSCRITS, SEMAINES, ENFANTS " & _
             "WHERE ENFANTS.Num_enfant = INSCRITS.Num_enfant " & _
             "AND INSCRITS.Num_semaine = SEMAINES.Num_semaine " & _
             "And Scolarise_lexy = True And SEMAINES.Nom IN ('H-1','H-2')  And SEMAINES.Annee= " & Annee & ";"
     
    Set Rst = Db.OpenRecordset(Source, dbOpenDynaset)
    If Not Rst.EOF Then
        Rst.MoveLast
        Sco_lex_hiver = Rst.Recordcount
    Else
        Sco_lex_hiver = 0
    End If
    A+

Discussions similaires

  1. Requête avec COUNT et DISTINCT ?
    Par kateo dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 27/04/2012, 22h33
  2. Requête: Count avec un IF et Distinct
    Par Sethenssen dans le forum Requêtes
    Réponses: 8
    Dernier message: 04/11/2009, 13h35
  3. Problème de requête SQL avec DISTINCT et COUNT ?
    Par [ZiP] dans le forum Langage SQL
    Réponses: 4
    Dernier message: 29/01/2007, 17h11
  4. probleme count et distinct
    Par Yphon dans le forum Bases de données
    Réponses: 5
    Dernier message: 23/09/2005, 09h35
  5. PB avec une requête Count
    Par Marion dans le forum ASP
    Réponses: 7
    Dernier message: 05/07/2004, 12h56

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