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

Langage SQL Discussion :

Requête avec fonction Count


Sujet :

Langage SQL

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    262
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 262
    Points : 113
    Points
    113
    Par défaut Requête avec fonction Count
    Bonjour,

    Je me suis inspiré d'une de mes demandes mais malgré cela je ne trouve pas.

    J'ai dans une table comme renseignements

    Num Dossier (NUHOAC)
    Date Execution (DAEXAC)
    Code Acte (NULCAC)

    Je cherche à connaitre les dossiers ayant plusieurs fois le code acte = C pour la même date d’exécution.

    Voici ma requete:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    SELECT NUHOAC 
        , trunc(DAEXAC, 'DD') AS jour_intervention
    FROM ACC 
      WHERE DAEXAC < '01062013' 
      AND DAEXAC > '26052013' 
      AND NULCAC = 'C'
    GROUP BY NUHOAC
      , trunc(DAEXAC, 'DD')
    HAVING COUNT(DISTINCT NULCAC) > 2;
    Merci d'avance

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 244
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 244
    Points : 12 878
    Points
    12 878
    Par défaut
    Bonjour,
    Le problème vient du count(distinct NULCAC). Comme la requête ne prend en compte que les lignes dont cette colonne vaut 'C', un count(distinct 'C') ne peut que renvoyer 1.

    Je verrait plutôt ceci:
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    SELECT NUHOAC 
        , trunc(DAEXAC, 'DD') AS jour_intervention,count(*)
    FROM ACC 
      WHERE DAEXAC < '01062013' 
      AND DAEXAC > '26052013' 
      AND NULCAC = 'C'
    GROUP BY NUHOAC
      , trunc(DAEXAC, 'DD')
    HAVING COUNT(*) > 2

    Tatayo.

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    262
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 262
    Points : 113
    Points
    113
    Par défaut
    Merci
    Cela marche

  4. #4
    J1
    J1 est déconnecté
    Membre averti Avatar de J1
    Inscrit en
    Mai 2004
    Messages
    321
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 321
    Points : 335
    Points
    335
    Par défaut
    Bonjour,

    je pense que tatayo a dit l'essentiel.
    Néanmoins, si je me fie à l'énoncé de ta demande...
    Citation Envoyé par islande Voir le message
    Je cherche à connaitre les dossiers ayant plusieurs fois le code acte = C pour la même date d’exécution.
    ... ta condition HAVING COUNT(*) > 2 devrait être remplacée par HAVING COUNT(*) > 1

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

Discussions similaires

  1. Requête sur deux tables avec fonction COUNT
    Par islande dans le forum Langage SQL
    Réponses: 13
    Dernier message: 12/08/2013, 16h06
  2. [MySQL] Optimisation requête avec SELECT COUNT
    Par przvl dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 15/10/2008, 15h27
  3. requête avec fonction logarithmique
    Par nefertari dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 25/07/2007, 14h39
  4. Requête avec fonction Sum
    Par freud dans le forum Bases de données
    Réponses: 3
    Dernier message: 12/02/2007, 13h32
  5. requête avec fonction week()
    Par Sebastien_INR59 dans le forum Requêtes et SQL.
    Réponses: 10
    Dernier message: 27/06/2006, 18h05

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