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

SQL Oracle Discussion :

Question Fonction analytique


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Expert confirmé
    Avatar de SheikYerbouti
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    6 760
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 6 760
    Par défaut Question Fonction analytique
    Oracle Database 11g Enterprise Edition Release 11.1.0.7.0

    Soit la table T1
    TYPE Varchar2
    ANNEE Number
    MOIS Number
    CODE Varchar2
    VALEUR Number
    Je souhaite, pour chaque tuple TYPE, ANNEE et CODE retrouver la valeur du mois le plus elevé.
    Par exemple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    TYPE ANNEE MOIS CODE VALEUR
    1     2000  1    C1   1.0
    1     2000  3    C1   1.2
    1     2000  9    C1   1.3
    doit retourner la ligne les valeurs:
    1,2000,C1,1.3 (en l'occurence le mois 9)
    Je pense qu'une fonction analytique doit permettre de donner ce résultat dans le meilleur délai, compte tenu du nombre important de lignes dans la table
    D'avance merci

  2. #2
    Expert confirmé Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Par défaut
    Salut SheikYerbouti,

    Pour quoi une fonction analytique la où une simple aggregation suffit ?
    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
     
    Connected to Oracle Database 10g Enterprise Edition Release 10.2.0.4.0 
    Connected as mni
     
    SQL> 
    SQL> With Data As (
      2    select 1 as typ,  2000 as annee,  1 as mois,  'C1' as code, 1.0 as valeur from dual union all
      3    select 1,2000,3,'C1',1.2 from dual union all
      4    select 1,2000,9,'C1',1.3 from dual
      5  )
      6  select typ, annee, code, max(mois) mois, max(valeur)  keep (dense_rank last order by mois) valuer
      7  from data
      8  group by typ, annee, code
      9  /
     
           TYP      ANNEE CODE       MOIS     VALUER
    ---------- ---------- ---- ---------- ----------
             1       2000 C1            9        1,3
     
    SQL>

  3. #3
    Expert confirmé
    Avatar de SheikYerbouti
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    6 760
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 6 760
    Par défaut
    Merci.
    Il me semblait que "dense_rank" faisait parti de la syntaxe des fonctions analytiques.
    Concernant le code donné, notament le max(valeur) je précise que je ne souhaite pas la valeur la plus élevée, mais celle qui correspond au mois le plus grand pour le tuple donné.

  4. #4
    Expert confirmé
    Avatar de SheikYerbouti
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    6 760
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 6 760
    Par défaut
    Toujours est-il que le code donné fourni le résultat attendu.
    merci bien

  5. #5
    Expert confirmé Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Par défaut
    Salut SheikYerbouti,
    En fait c'est la fonction Last qui peut être utilisée comme une fonction aggrégée ou analytique.
    J’utilise souvent la règle suivante: si j'ai besoin du détail et d'une agrégation j'emploie des fonctions analytiques si non c'est très probable que l'agrégation suffit.

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

Discussions similaires

  1. Question fonction analytique
    Par SheikYerbouti dans le forum SQL
    Réponses: 3
    Dernier message: 10/03/2008, 12h16
  2. [Excel] question fonction !!!
    Par Fealendril dans le forum Macros et VBA Excel
    Réponses: 17
    Dernier message: 25/01/2006, 19h21
  3. Réponses: 3
    Dernier message: 24/11/2005, 12h19
  4. Réponses: 7
    Dernier message: 21/11/2005, 14h21
  5. Réponses: 4
    Dernier message: 18/08/2005, 16h11

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