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

MS SQL Server Discussion :

compter : comment utiliser COUNT !


Sujet :

MS SQL Server

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    343
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 343
    Par défaut compter : comment utiliser COUNT !
    Bonjour,

    voici ma requéte SQL qui fonctionne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT	sub.SUB_NAME		AS	SubscriptionName,
    		sub.SUB_PRICE		AS	Price,
    		sur.SUR_DATE_END	As	DateEnd
    FROM DMJ_SUBSCRIBERS AS sur
    inner join DMJ_SUBSCRIPTIONS AS sub on sub.SUB_ID = sur.SUB_ID
    WHERE sur.ASK_CI='802030' AND sur.SUR_DATE_END>=GetDate()
    je cherche à compter le nombre de sub.SUB_NAME et ainsi n'avoir qu'une seule ligne par sub.SUB_NAME...
    je sais qu'il faut utiliser COUNT mais je ne sais comment l'utiliser justement...

    merci de m'aider !

  2. #2
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Par défaut
    Bonjour,

    Essaie ceci:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    SELECT	sub.SUB_NAME SubscriptionName,
    		sub.SUB_PRICE Price,
    		sur.SUR_DATE_END DateEnd,
    		COUNT(*) NB
    FROM DMJ_SUBSCRIBERS sur
    INNER JOIN DMJ_SUBSCRIPTIONS sub ON sub.SUB_ID = sur.SUB_ID
    WHERE sur.ASK_CI='802030'
    AND sur.SUR_DATE_END >= GetDate()
    GROUP BY sub.SUB_NAME, sub.SUB_PRICE, sur.SUR_DATE_END

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    343
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 343
    Par défaut
    j'ai essayé mais apparement ça ne marche pas puisque j'ai en résultats ceci :

    TENNIS MAGAZINE 69.99 2008-11-22 11:59:58.287 1
    TENNIS MAGAZINE 69.99 2008-11-23 12:30:46.323 1

    moi je veux la même chose mais comme ça :
    TENNIS MAGAZINE 69.99 2008-11-22 11:59:58.287 2

    en ne gardant comme date que la plus proche... (désolé je ne l'avais pas mentionné).

    je vais faire des essais à partir de ta proposition mais merci de continuer à m'aider!
    au passage peux tu m'expliquer "GROUP BY" que tu utilises dans la requète que tu m'as proposé?

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    343
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 343
    Par défaut
    résolu tout seul !

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    SELECT	sub.SUB_NAME		AS	SubscriptionName,
    	sub.SUB_PRICE		AS	Price,
    	MIN(sur.SUR_DATE_END)	AS	DateEnd,
    	COUNT(*)		AS	NB
    FROM DMJ_SUBSCRIBERS sur
    INNER JOIN DMJ_SUBSCRIPTIONS AS sub ON sub.SUB_ID = sur.SUB_ID
    WHERE sur.ASK_CI='802030'
    AND sur.SUR_DATE_END >= GetDate()
    GROUP BY sub.SUB_NAME, sub.SUB_PRICE
    mais je veux bien que tu m'expliques le GROUP BY quand même pour comprendre pour la prochaine fois !

    merci en tout cas d'avoir bien voulu m'aider ...

  5. #5
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Par défaut
    Et ben voilà

    pour le GROUP BY, cela indique sur quelles colonnes tu souhaites grouper tes données lorsque tu utilises une fonction d'aggrégation comme COUNT, MIN, MAX ... le mieux est que tu regardes la documentation, elle te l'expliquera le plus complètement et te détaillera les possibilités (HAVING, WITH ROLLUP, ...)

    Il te faut maintenant marquer ton post comme résolu

  6. #6
    Membre émérite
    Avatar de Reskibil
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    561
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mai 2007
    Messages : 561
    Par défaut
    Et ca ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    SELECT	sub.SUB_NAME SubscriptionName,
    		sub.SUB_PRICE Price,
    		max(sur.SUR_DATE_END) DateEnd,
    		COUNT(*) NB
    FROM DMJ_SUBSCRIBERS sur
    INNER JOIN DMJ_SUBSCRIPTIONS sub ON sub.SUB_ID = sur.SUB_ID
    WHERE sur.ASK_CI='802030'
    AND sur.SUR_DATE_END >= GetDate()
    GROUP BY sub.SUB_NAME, sub.SUB_PRICE, sur.SUR_DATE_END
    Pour le group by, ca te permet de regrouper les lignes dont tous les champs sont identiques. Si tu le met pas avec un count, tu auras 1 à chaque ligne car chaque ligne sera unique.

  7. #7
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    343
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 343
    Par défaut
    oki merci bcp...

    pour Reskibil, merci aussi mais ta réponse serait plutôt pour la date la plus tardive et en plus tu gardes le sur.SUR_DATE_END dans GROUP BY...
    mais bon c'est de ma faute, j'ai mal expliqué mes attentes...

    merci encore à tous 2 (je mets en résolu)

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

Discussions similaires

  1. comment utiliser count(*) dans Run if
    Par zinabd dans le forum Développement de jobs
    Réponses: 2
    Dernier message: 14/11/2011, 09h07
  2. comment utiliser SELECT COUNT dans ma fonction
    Par z_ahlam dans le forum Langage
    Réponses: 2
    Dernier message: 14/10/2009, 16h30
  3. comment utiliser mon count
    Par Basicnav dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 07/08/2009, 09h50
  4. Comment utiliser OUT ?
    Par Bouziane Abderraouf dans le forum CORBA
    Réponses: 3
    Dernier message: 20/07/2002, 09h35
  5. Réponses: 5
    Dernier message: 11/06/2002, 15h21

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