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

Développement SQL Server Discussion :

SUM + sous requête


Sujet :

Développement SQL Server

  1. #1
    Membre du Club
    Inscrit en
    Novembre 2010
    Messages
    150
    Détails du profil
    Informations forums :
    Inscription : Novembre 2010
    Messages : 150
    Points : 67
    Points
    67
    Par défaut SUM + sous requête
    bonjour,

    j'essaye d'avoir la somme de cette requete mais quand j'insère SUM cela renvoie une erreur

    impossible d’exécuter une fonction d'agrégation sur une expression comportant un agrégat ou une sous requête

    voila la requête de base
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT dbo.etat_engagement.montant_engager + SUM(ISNULL(dbo.modification_engager.montant, 0)) AS engager
    FROM  dbo.etat_engagement LEFT OUTER JOIN
    dbo.modification_engager ON dbo.etat_engagement.id2 = dbo.modification_engager.id2
    WHERE (NOT (dbo.etat_engagement.n_certification LIKE ''))
    GROUP BY dbo.etat_engagement.montant_engager

    erreur obtenu quand je mis SUM
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT SUM(dbo.etat_engagement.montant_engager + SUM(ISNULL(dbo.modification_engager.montant, 0))) AS somme_engager

  2. #2
    Membre émérite

    Homme Profil pro
    Chargé de Développement et d'Analyse de données
    Inscrit en
    Mars 2010
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Chargé de Développement et d'Analyse de données
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2010
    Messages : 1 278
    Points : 2 856
    Points
    2 856
    Par défaut
    Essaye avec ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT SUM(dbo.etat_engagement.montant_engager + ISNULL(dbo.modification_engager.montant, 0)) AS somme_engager

  3. #3
    Membre du Club
    Inscrit en
    Novembre 2010
    Messages
    150
    Détails du profil
    Informations forums :
    Inscription : Novembre 2010
    Messages : 150
    Points : 67
    Points
    67
    Par défaut
    dsl mais c'est pas ce que je cherche
    il ya plusieurs montant modifié pour un montant engager c'est pour cela je calcule le montant engagée + la somme des montant modifié

    ma requête est déjà bien sauf j'aimerai avoir une seul montant la sum de tous

  4. #4
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Octobre 2009
    Messages
    118
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2009
    Messages : 118
    Points : 27
    Points
    27
    Par défaut
    Tu dois faire une sous requete, si tu es est 2005 ou plus tu peux faire :

    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
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
     
     
    WITH 
    	modification_CTE as ( 
    	SELECT
    		etat_engagement.id2
    		, SUM( dbo.modification_engager.montant ) AS engager
    	FROM  
    		dbo.modification_engager
    	INNER JOIN
    		dbo.etat_engagement 
    	ON 
    		dbo.etat_engagement.id2 = dbo.modification_engager.id2
    		AND dbo.etat_engagement.n_certification != ''
    	GROUP BY 
    		etat_engagement.id2
    	)
    SELECT
    	dbo.etat_engagement.montant_engager + cte.engager
    FROM
    	dbo.etat_engagement 
    LEFT OUTER JOIN
    	dbo.modification_CTE
    ON 
    	dbo.etat_engagement.id2 = modification_CTE.id2
    WHERE
    	dbo.etat_engagement.n_certification != ''
    Au passage je ne comprend pas la ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    NOT (dbo.etat_engagement.n_certification LIKE ''))
    il faut éviter les like dans la mesure du possible, un simple opérateur différent suffit dans ton cas, si j'ai bien compris

    A+

  5. #5
    Membre du Club
    Inscrit en
    Novembre 2010
    Messages
    150
    Détails du profil
    Informations forums :
    Inscription : Novembre 2010
    Messages : 150
    Points : 67
    Points
    67
    Par défaut
    Citation Envoyé par Batou69 Voir le message
    Au passage je ne comprend pas la ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    NOT (dbo.etat_engagement.n_certification LIKE ''))
    il faut éviter les like dans la mesure du possible, un simple opérateur différent suffit dans ton cas, si j'ai bien compris

    A+
    je vais testé ça
    pour
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    NOT (dbo.etat_engagement.n_certification LIKE ''))
    =>dont n_certification est pas vide

  6. #6
    Membre éprouvé

    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 448
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 448
    Points : 1 234
    Points
    1 234
    Par défaut
    zinzineti vous a donné la solution.

    Elle implique que vous supprimiez la clause "GROUP BY" si cela vous avait échappé.

  7. #7
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Octobre 2009
    Messages
    118
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2009
    Messages : 118
    Points : 27
    Points
    27
    Par défaut
    Citation Envoyé par Sergejack Voir le message
    zinzineti vous a donné la solution.

    Elle implique que vous supprimiez la clause "GROUP BY" si cela vous avait échappé.
    Je ne suis pas d'accord avec toi, car si la table modification_engager contient plusieurs ligne pour chaque id2, alors, la somme va multiplier le etat_engagement.montant_engager inutilement. Et je crois que ce n'est pas le but recherché.

    A+

  8. #8
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    Bonjour,

    Vous pouvez aussi faire comme ceci :

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    SELECT 
        dbo.etat_engagement.montant_engager 
        +(
            SELECT SUM(ISNULL(dbo.modification_engager.montant, 0)) 
            FROM modification_engager 
            WHERE etat_engagement.id2 = modification_engager.id2
        )    AS engager
    FROM  dbo.etat_engagement 
    WHERE etat_engagement.n_certification <> ''

    ou encore
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    SELECT 
        dbo.etat_engagement.montant_engager + somme.montant  AS engager
    FROM  dbo.etat_engagement 
    CROSS APPLY (
            SELECT SUM(ISNULL(dbo.modification_engager.montant, 0))  AS Montant
            FROM modification_engager 
            WHERE etat_engagement.id2 = modification_engager.id2
        )    Somme
    WHERE etat_engagement.n_certification <> ''

  9. #9
    Membre éprouvé

    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 448
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 448
    Points : 1 234
    Points
    1 234
    Par défaut
    Citation Envoyé par Batou69 Voir le message
    Je ne suis pas d'accord avec toi, car si la table modification_engager contient plusieurs ligne pour chaque id2, alors, la somme va multiplier le etat_engagement.montant_engager inutilement. Et je crois que ce n'est pas le but recherché.

    A+
    Au temps pour moi.

    Pour m'excuser voici une façon poilante (...) de résoudre votre problème sans sous query :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    SELECT top(1)
    SUM (dbo.etat_engagement.montant_engager)   over (partition by dbo.etat_engagement.id2) + SUM(ISNULL(dbo.modification_engager.montant, 0)) AS engager over()
    FROM  dbo.etat_engagement LEFT OUTER JOIN
    dbo.modification_engager ON dbo.etat_engagement.id2 = dbo.modification_engager.id2

  10. #10
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Octobre 2009
    Messages
    118
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2009
    Messages : 118
    Points : 27
    Points
    27
    Par défaut
    Arf, alors celle là, je comprends même pas la requete.

    Mais je vais me documenter sur le over dans un sum.....

  11. #11
    Membre du Club
    Inscrit en
    Novembre 2010
    Messages
    150
    Détails du profil
    Informations forums :
    Inscription : Novembre 2010
    Messages : 150
    Points : 67
    Points
    67
    Par défaut
    merci pour votre réponse
    pour la solution de aieeeuuuuu & Sergejack je peut pas l'utilisée parceque sqlserver 2005 express pris pas en charge l'instruction CROSS APPLY | OVER

    pour la réponse de Batou69
    erreur
    dbo.modification_CTE non valide

  12. #12
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Octobre 2009
    Messages
    118
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2009
    Messages : 118
    Points : 27
    Points
    27
    Par défaut
    Citation Envoyé par jalalnet Voir le message
    merci pour votre réponse
    pour la réponse de Batou69
    erreur
    dbo.modification_CTE non valide
    Oui, n'ayant pas les tables que tu as, je n'ai pas pu tester la requete. Il faut enlever le nom du schema (dbo) et cela devrait fonctionner.

  13. #13
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    Citation Envoyé par jalalnet Voir le message
    pour la solution de aieeeuuuuu & Sergejack je peut pas l'utilisée parceque sqlserver 2005 express pris pas en charge l'instruction CROSS APPLY | OVER


    sauf erreur de ma part (ou exception de la version Exrpress ?), la version 2005 prend bien en charge le CROSS APPLY, tout comme les fonctions de fentrage... Etes vous sur de la version ? quel est le message d'erreur que vous avez ?

    sinon, avez vous essayé ma première requête, qui n'utilise pas le CROSS APPLY ?

  14. #14
    Membre du Club
    Inscrit en
    Novembre 2010
    Messages
    150
    Détails du profil
    Informations forums :
    Inscription : Novembre 2010
    Messages : 150
    Points : 67
    Points
    67
    Par défaut
    Citation Envoyé par aieeeuuuuu Voir le message


    sauf erreur de ma part (ou exception de la version Exrpress ?), la version 2005 prend bien en charge le CROSS APPLY, tout comme les fonctions de fentrage... Etes vous sur de la version ? quel est le message d'erreur que vous avez ?

    sinon, avez vous essayé ma première requête, qui n'utilise pas le CROSS APPLY ?
    pour ta première requête c'est comme la mienne il renvoie la somme du montant engagé + somme(modification) pour chaque ligne
    mais moi je cherche la somme de tous

    est pour la deuxième quand j’exécute pour la première fois
    j'ai l erreur :
    La construction ou l'instruction SQL CROSS APPLY n'est pas prise en charge.
    est après
    l'identificateur en plusieurs parties somme.montant ne peut pas être lié

  15. #15
    Membre du Club
    Inscrit en
    Novembre 2010
    Messages
    150
    Détails du profil
    Informations forums :
    Inscription : Novembre 2010
    Messages : 150
    Points : 67
    Points
    67
    Par défaut
    Citation Envoyé par Batou69 Voir le message
    Oui, n'ayant pas les tables que tu as, je n'ai pas pu tester la requete. Il faut enlever le nom du schema (dbo) et cela devrait fonctionner.
    je l'ai enlevé puis nouveau erreur
    l'identificateur en plusieurs parties cte.engager ne peut pas être liè

  16. #16
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    Citation Envoyé par jalalnet Voir le message
    pour ta première requête c'est comme la mienne il renvoie la somme du montant engagé + somme(modification) pour chaque ligne
    mais moi je cherche la somme de tous

    Un petit jeu de données + resultat attendu serait sans doute plus clair...

    est-ce ceci que vous voulez ?
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    SELECT 
        SUM(dbo.etat_engagement.montant_engager )
        +(
            SELECT SUM(ISNULL(dbo.modification_engager.montant, 0)) 
            FROM modification_engager 
            WHERE etat_engagement.id2 = modification_engager.id2
        )    AS engager
    FROM  dbo.etat_engagement 
    WHERE etat_engagement.n_certification <> ''
    GROUP BY etat_engagement.id2

  17. #17
    Membre du Club
    Inscrit en
    Novembre 2010
    Messages
    150
    Détails du profil
    Informations forums :
    Inscription : Novembre 2010
    Messages : 150
    Points : 67
    Points
    67
    Par défaut
    ma requête de base
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT dbo.etat_engagement.montant_engager + SUM(ISNULL(dbo.modification_engager.montant, 0)) AS engager
    FROM  dbo.etat_engagement LEFT OUTER JOIN
    dbo.modification_engager ON dbo.etat_engagement.id2 = dbo.modification_engager.id2
    WHERE (NOT (dbo.etat_engagement.n_certification LIKE ''))
    GROUP BY dbo.etat_engagement.montant_engager
    résultat de la requête
    20000 => contient (montant engagée + sum modification du monatn engagée)
    15000
    22222
    .
    .
    .
    ce que je veut
    20000
    15000
    22222
    .
    .
    .

    75222 la somme de tous

  18. #18
    Membre expert Avatar de iberserk
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Novembre 2004
    Messages
    1 795
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 795
    Points : 3 173
    Points
    3 173
    Par défaut
    SELECT dbo.etat_engagement.montant_engager + SUM(ISNULL(dbo.modification_engager.montant, 0)) AS engager
    FROM dbo.etat_engagement LEFT OUTER JOIN
    dbo.modification_engager ON dbo.etat_engagement.id2 = dbo.modification_engager.id2
    WHERE (NOT (dbo.etat_engagement.n_certification LIKE ''))
    GROUP BY dbo.etat_engagement.montant_engager


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    WITH CTE AS(SELECT etat_engagement.montant_engager,dbo.etat_engagement.montant_engager + SUM(ISNULL(dbo.modification_engager.montant, 0)) AS engager
    FROM  dbo.etat_engagement LEFT OUTER JOIN
    dbo.modification_engager ON dbo.etat_engagement.id2 = dbo.modification_engager.id2
    WHERE (NOT (dbo.etat_engagement.n_certification LIKE ''))
    GROUP BY dbo.etat_engagement.montant_engager)
    SELECT engager
    FROM CTE 
    UNION ALL
    SELECT SUM(engager) as engager
    FROM CTE

  19. #19
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    donc vous voulez une ligne supplémentaire qui fait la somme de tous ?

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
     
    SELECT 
        etat_engagement.id2,
        SUM(etat_engagement.montant_engager  + somme) as montant
    FROM  dbo.etat_engagement 
    LEFT OUTER JOIN  (
        SELECT 
            id2,
            SUM(ISNULL(dbo.modification_engager.montant, 0))  AS somme
        FROM modification_engager 
        GROUP BY modification_engager.id2
    )    T
        ON T.id2 = etat_engagement.id2
    WHERE etat_engagement.n_certification <> ''
    GROUP BY etat_engagement.id2 WITH ROLLUP

    La ligne ou etat_engagement.id2 est NULL, c'est le total

  20. #20
    Membre expert Avatar de iberserk
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Novembre 2004
    Messages
    1 795
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 795
    Points : 3 173
    Points
    3 173
    Par défaut
    Je préfère ma mienne NAH

+ Répondre à la discussion
Cette discussion est résolue.
Page 1 sur 2 12 DernièreDernière

Discussions similaires

  1. SUM et sous requête
    Par thriller dans le forum Langage SQL
    Réponses: 3
    Dernier message: 18/12/2009, 10h35
  2. un SUM + sous-requête pour remplacer une boucle itérative
    Par forzaxelah dans le forum Langage SQL
    Réponses: 2
    Dernier message: 29/03/2009, 23h16
  3. SUM, CASE, GROUP BY et sous requête
    Par wisrou dans le forum SQL
    Réponses: 2
    Dernier message: 13/02/2008, 14h19
  4. Pb sur SUM dans requête SQL exécutée sous VB
    Par MAKSIM dans le forum VB 6 et antérieur
    Réponses: 5
    Dernier message: 14/11/2006, 18h07
  5. Réponses: 3
    Dernier message: 18/05/2003, 01h16

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