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 :

Somme des derniers enregistrement


Sujet :

SQL Oracle

  1. #1
    Membre du Club
    Inscrit en
    Mars 2008
    Messages
    99
    Détails du profil
    Informations forums :
    Inscription : Mars 2008
    Messages : 99
    Points : 43
    Points
    43
    Par défaut Somme des derniers enregistrement
    Bonjour,
    Je vais tout d'abord décrire ma table et ma requête puis je vais énoncé le problème
    Ma table: MFT_AR_PROMO--Table de promotion
    - MFT_AR_PROMO_YRES: --L'identifiant de la réservation
    - MFT_AR_PROMO_SHORTDESC: --Description de la promotion
    - MFT_AR_PROMO_RULE: --Type de promotion
    - MFT_AR_PROMO_DATE: --Indique la date de chaque ligne du séjour par exemple si lé séjour dure 5 jours le champs date contient 5 dates donc la table promo pour cette réservation contient 5 lignes
    - MFT_AR_PROMO_MOUNT: -- Montant de la promotion pour chaque ligne
    Ma requête:
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    select * from (select MFT_AR_PROMO_SHORTDESC,MFT_AR_PROMO_DATE,MFT_AR_PROMO_YRES,
    MFT_AR_PROMO_RULE,ROW_NUMBER()OVER (ORDER BY MFT_AR_PROMO_DATE desc) Dat 
    from MFT_AR_PROMO 
    where MFT_AR_PROMO_YRES=66376 and MFT_AR_PROMO_RULE=1) where dat<=5
    Cette requête me retourne les 5 derniers enregistrement de la table promotion et elle marche correctement, mon problème c'est que je veux calculer ou introduire l'opérateur SUM (Somme) à cette requête pour me retourner la somme des ligne ou des enregistrement sélectionnées, exemple si je sélectionne les 2 première lignes je veux que la requête me retourne la somme du champs(MFT_AR_PROMO_MOUNT) des deux premières lignes et ainsi de suite, sachant que le nombre d'enregistrement et un paramètre modifiable
    Merci de m'aider
    Bonne journée

  2. #2
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 820
    Points
    17 820
    Par défaut
    Une petite illustration peut-être ?
    Je pense que vous pouvez le faire avec une somme analytique, sans partition :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    SELECT MFT_AR_PROMO_SHORTDESC, MFT_AR_PROMO_DATE,
           MFT_AR_PROMO_YRES, MFT_AR_PROMO_RULE,
           SUM(MFT_AR_PROMO_MOUNT) OVER()
      FROM
           (
           SELECT MFT_AR_PROMO_SHORTDESC, MFT_AR_PROMO_DATE,
                  MFT_AR_PROMO_YRES, MFT_AR_PROMO_RULE,
                  MFT_AR_PROMO_MOUNT,
                  ROW_NUMBER() OVER (ORDER BY MFT_AR_PROMO_DATE DESC) AS DAT 
             FROM MFT_AR_PROMO 
            WHERE MFT_AR_PROMO_YRES = 66376
              AND MFT_AR_PROMO_RULE = 1
           )
     WHERE DAT <= 5

  3. #3
    Membre du Club
    Inscrit en
    Mars 2008
    Messages
    99
    Détails du profil
    Informations forums :
    Inscription : Mars 2008
    Messages : 99
    Points : 43
    Points
    43
    Par défaut Somme des derniers enregistrement
    Voila j'ai effectué une petite modification sur ton code pour qu'il me retourne une seule ligne contenant la somme c'est tout car c'est ça mon objectif et je vous merci pour votre aide.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    SELECT SUM(MFT_AR_PROMO_MOUNT) OVER() as Somme 
      FROM
           (
           SELECT MFT_AR_PROMO_SHORTDESC, MFT_AR_PROMO_DATE,
                  MFT_AR_PROMO_YRES, MFT_AR_PROMO_RULE,
                  MFT_AR_PROMO_MOUNT,
                  ROW_NUMBER() OVER (ORDER BY MFT_AR_PROMO_DATE DESC) AS DAT 
             FROM MFT_AR_PROMO 
            WHERE MFT_AR_PROMO_YRES = 66376
              AND MFT_AR_PROMO_RULE = 1
           )
     WHERE DAT <= 5

  4. #4
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 820
    Points
    17 820
    Par défaut
    S'il vous faut une seule ligne utilisez le SUM classique (supprimez juste la clause OVER de votre requête).

  5. #5
    Membre du Club
    Inscrit en
    Mars 2008
    Messages
    99
    Détails du profil
    Informations forums :
    Inscription : Mars 2008
    Messages : 99
    Points : 43
    Points
    43
    Par défaut Somme des derniers enregistrement
    Peut être que je l'ai oublié mais c'est pas grave en tout cas merci pour ce réflexe c'est génial

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

Discussions similaires

  1. Somme sur dernier enregistrement
    Par JackiJack dans le forum QlikView
    Réponses: 4
    Dernier message: 27/08/2012, 15h56
  2. Export/Import des derniers enregistrements d'une table
    Par essayeencore dans le forum Développement
    Réponses: 2
    Dernier message: 04/03/2010, 11h33
  3. Sélection des derniers enregistrements de chaque jour
    Par sebastyen dans le forum Langage SQL
    Réponses: 2
    Dernier message: 19/05/2009, 12h36
  4. [debutant] selection des 6 derniers enregistrements
    Par LoLoSS dans le forum Langage SQL
    Réponses: 4
    Dernier message: 09/07/2004, 15h27
  5. Réponses: 10
    Dernier message: 01/08/2003, 13h45

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