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

Oracle Discussion :

Moyenne conditionnée fonction AVG ?


Sujet :

Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre chevronné
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    434
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2004
    Messages : 434
    Par défaut Moyenne conditionnée fonction AVG ?
    Bonjour à tous,

    Je souhaiterais faire une moyenne sur deux colonnes d'une table en supprimant les valeurs égales à 0.

    Voici ce que je souhaite faire :

    Table toto (id, date, montant1, montant2) ; id et date représentant la clef de l'enregistrement

    supposons les lignes suivantes

    1,34,0,17
    1,34,9,28
    1,35,10,10
    1,35,10,0


    je voudrais avoir le résultat suivant

    1,34,9, avg(17,28)
    1,35, avg(10,10), 10


    j'ai tenté le select avec la fonction AVG.

    Mais les valeurs à 0 sont dans la moyenne, dès lors je n'ai pas le résultat que je souhaite avoir.
    par example, pour l'enregistrement 1(;35), la moyenne du montant2 est renvoyé à 5 (10+0/2 car deux enregistrements dans la table). Or je souhaite que la valeur renvoyée soit 10 car je ne veux pas que la valeur 0 soit comptabilisée dans la moyenne.

    Merci de votre aide.

    cdlt

  2. #2
    Invité
    Invité(e)
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    select id, date, avg(montant2)
    from toto
    where montant2 != 0
    group by id, date
    ou plus tordu :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    select id, date, avg(case when montant2 = 0 then nulll else montant2 end)
    from toto
    group by id, date

  3. #3
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    Pour éviter le case un peu long :
    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
    With toto as
    (
    select 1 as id, 34 as dt,  0 as mt1, 17 as mt2 from dual union all
    select 1      , 34      ,  9       , 28        from dual union all
    select 1      , 35      , 10       , 10        from dual union all
    select 1      , 35      , 10       ,  0        from dual
    )
      select id, dt
           , avg(nullif(mt1, 0)) as mt1_avg
           , avg(nullif(mt2, 0)) as mt2_avg
        from toto
    group by id, dt
    order by id, dt;
     
            ID         DT    MT1_AVG    MT2_AVG
    ---------- ---------- ---------- ----------
             1         34          9       22.5
             1         35         10         10

  4. #4
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 461
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant / formateur Oracle et SQL Server

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 461
    Par défaut
    Citation Envoyé par 7gyY9w1ZY6ySRgPeaefZ Voir le message
    ou plus tordu :
    Moi j'ai pensé tout de suite à la solution tordue (avec un bon vieux DECODE), mais je me suis abstenu car votre solution initiale peut profiter d'un index éventuel.

  5. #5
    Membre Expert Avatar de pacmann
    Homme Profil pro
    Consulté Oracle
    Inscrit en
    Juin 2004
    Messages
    1 626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Consulté Oracle
    Secteur : Distribution

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 626
    Par défaut
    Salut,

    Sauf que la solution pas tordue ne marche pas : comme il y a deux colonnes qui doivent être calculées, si l'une vaut 0, toute la ligne est éliminée alors que l'autre est éventuellement non nulle (et pas NULLe )

    Waldar, c'est lent le case ?

  6. #6
    Membre chevronné
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    434
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2004
    Messages : 434
    Par défaut
    Bonjour à tous,

    merci pour vos réponses.

    Je vais tester la solution de waldar tout de suite car j'avais déjà programmé les autres mais elles ne donnaient pas du tout ce que je souhaite puique deux colonnes sont à tester et pas une.

    Cordialement

    Edit : testé et validé !

    Merci !

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

Discussions similaires

  1. Moyennes avec fonction avg
    Par bati_taf dans le forum QlikView
    Réponses: 5
    Dernier message: 27/10/2013, 09h42
  2. [XQUERY] Fonction AVG (MOYENNE ) sur base d'attributs
    Par radulew dans le forum XQUERY/SGBD
    Réponses: 2
    Dernier message: 16/09/2013, 17h49
  3. Fonction AVG(CombustibilConsumat) moyenne combustible consomme
    Par mihaispr dans le forum MS SQL Server
    Réponses: 7
    Dernier message: 12/11/2009, 12h13
  4. Problème avec la fonction AVG
    Par cirtey dans le forum SQL Procédural
    Réponses: 6
    Dernier message: 02/05/2007, 13h03

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