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 :

[SQL] Combiner fonction d'agrégation et DISTINCT .


Sujet :

Langage SQL

  1. #1
    Membre du Club
    Profil pro
    ingénieur
    Inscrit en
    Octobre 2004
    Messages
    56
    Détails du profil
    Informations personnelles :
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : ingénieur

    Informations forums :
    Inscription : Octobre 2004
    Messages : 56
    Points : 66
    Points
    66
    Par défaut [Résolu][SQL] Combiner fonction d'agrégation et DISTINCT .
    salut à toutes à à tous,

    j'ai pb sur une requete , voici ma requete d'origine :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT PHYSIC_PAGEID_PK , ISNULL(SUM(NUMBERPOSTINGPAGES),0) 
    AS NB 
    FROM TRACKING_PHYSIC_PAGE  , TRACKING_POSTING_PAGE , TRACKING_DAILY_CALENDAR 
    WHERE PHYSIC_PAGEID_PK = PHYSIC_PAGEID_FK 
    	AND DAILY_CALENDARID_FK = DAILY_CALENDARID_PK
    	AND YEAR = 2004 GROUP BY PHYSIC_PAGEID_PK ORDER BY NB DESC
    je souhaite faire un distinct sur un champs nommé PHYSIC_PAGEURL de la table TRACKING_PHYSIC_PAGE , j'ai pensé à une sous requete mais je ne vois pas trops ou la mettre.. un peu d'aide serait binevenue ..
    merci !!

    ps : sgbd : sql server

  2. #2
    Membre actif
    Inscrit en
    Février 2003
    Messages
    182
    Détails du profil
    Informations forums :
    Inscription : Février 2003
    Messages : 182
    Points : 206
    Points
    206
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Select PHYSIC_PAGEID_PK , NB
    From
    (SELECT PHYSIC_PAGEID_PK ,
                 ISNULL(SUM(NUMBERPOSTINGPAGES),0) AS NB 
    FROM TRACKING_PHYSIC_PAGE  , TRACKING_POSTING_PAGE , TRACKING_DAILY_CALENDAR 
    WHERE PHYSIC_PAGEID_PK = PHYSIC_PAGEID_FK 
       AND DAILY_CALENDARID_FK = DAILY_CALENDARID_PK 
       AND YEAR = 2004 GROUP BY PHYSIC_PAGEID_PK)
     ORDER BY NB DESC
    A+

  3. #3
    Membre du Club
    Profil pro
    ingénieur
    Inscrit en
    Octobre 2004
    Messages
    56
    Détails du profil
    Informations personnelles :
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : ingénieur

    Informations forums :
    Inscription : Octobre 2004
    Messages : 56
    Points : 66
    Points
    66
    Par défaut
    Citation Envoyé par MAMMAR
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Select PHYSIC_PAGEID_PK , NB
    From
    (SELECT PHYSIC_PAGEID_PK ,
                 ISNULL(SUM(NUMBERPOSTINGPAGES),0) AS NB 
    FROM TRACKING_PHYSIC_PAGE  , TRACKING_POSTING_PAGE , TRACKING_DAILY_CALENDAR 
    WHERE PHYSIC_PAGEID_PK = PHYSIC_PAGEID_FK 
       AND DAILY_CALENDARID_FK = DAILY_CALENDARID_PK 
       AND YEAR = 2004 GROUP BY PHYSIC_PAGEID_PK)
     ORDER BY NB DESC
    A+
    merci MAMMAR, mais,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Serveur : Msg 156, Niveau 15, État 1, Ligne 9
    Syntaxe incorrecte vers le mot clé 'ORDER'.
    me dit sql server...

    en virant ç ame fait


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Serveur : Msg 170, Niveau 15, État 1, Ligne 8
    Ligne 8 : syntaxe incorrecte vers ')'.

  4. #4
    Membre actif
    Inscrit en
    Février 2003
    Messages
    182
    Détails du profil
    Informations forums :
    Inscription : Février 2003
    Messages : 182
    Points : 206
    Points
    206
    Par défaut
    normal il manquait un alias pour la sous requête.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Select PHYSIC_PAGEID_PK , NB 
    From 
    (SELECT PHYSIC_PAGEID_PK , 
                 ISNULL(SUM(NUMBERPOSTINGPAGES),0) AS NB 
    FROM TRACKING_PHYSIC_PAGE  , TRACKING_POSTING_PAGE , TRACKING_DAILY_CALENDAR 
    WHERE PHYSIC_PAGEID_PK = PHYSIC_PAGEID_FK 
       AND DAILY_CALENDARID_FK = DAILY_CALENDARID_PK 
       AND YEAR = 2004 GROUP BY PHYSIC_PAGEID_PK)  as TRACK
     ORDER BY NB DESC
    A+

  5. #5
    Membre du Club
    Profil pro
    ingénieur
    Inscrit en
    Octobre 2004
    Messages
    56
    Détails du profil
    Informations personnelles :
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : ingénieur

    Informations forums :
    Inscription : Octobre 2004
    Messages : 56
    Points : 66
    Points
    66
    Par défaut
    ok merci

    A+

  6. #6
    Membre actif
    Inscrit en
    Février 2003
    Messages
    182
    Détails du profil
    Informations forums :
    Inscription : Février 2003
    Messages : 182
    Points : 206
    Points
    206
    Par défaut
    n'oublies pas le tag [Resolu].

    A+

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 16/05/2012, 09h48
  2. [A-07] SQL erreur fonction agrégat compte max
    Par chus03 dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 27/12/2008, 21h53
  3. [sql] Erreur n'est pas fonction d'agrégat
    Par Jahprend dans le forum Access
    Réponses: 13
    Dernier message: 05/07/2006, 13h34
  4. [SQL-Serveur][Sybase]Fonctions d'agrégat imbriquées
    Par vincenteraptor dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 09/06/2006, 09h46
  5. Quel SGBD permet d'écrire ses fonctions d'agrégation SQL?
    Par Machin0410 dans le forum Décisions SGBD
    Réponses: 1
    Dernier message: 28/03/2006, 17h31

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