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 :

Calculer les km parcourus chaque année


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2016
    Messages
    199
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Juillet 2016
    Messages : 199
    Par défaut Calculer les km parcourus chaque année
    Bonjour,
    J'ai deux tables et je voudrais afficher le nombre total de kilomètres parcourus chaque année.

    J'ai fait un select :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    with s as (select trunc(date1, 'YYYY') as year1, sum(cout_carburant) as cout_carburant1, sum(kilometrage) as km from mv_cout_carburant where vehicule = :P13_VEHICULE group by trunc(date1, 'YYYY') order by 1),
    y as (select trunc(t.date_travaux, 'yyyy') as date_travaux, sum(nvl(t.montant_facture,0)) as montant_facture1 from mv_entretien t where vehicule=:P13_VEHICULE GROUP by trunc(t.date_travaux, 'yyyy'))
    select year1, cout_carburant1, km, cout_carburant1+nvl(montant_facture1,0) "carburant+factures", nvl(montant_facture1,0) "Factures", round ( (cout_carburant1+nvl(montant_facture1,0))/KM, 3) "PRK" from s, y
    where s.year1 = y.date_travaux (+)
    order by year1;
    Le résultat est :

    Nom : Snap 2020-10-06 at 16.39.01.png
Affichages : 600
Taille : 17,7 Ko

    Mais malheureusement, le PRK est calculé pour le nombre total de kilomètres dans la colonne KM. Je voudrais ajouter une colonne affichant les kilomètres parcourus chaque année et la PRK correspondant aux kilomètres parcourus chaque année. Je pense qu'il devrait y avoir une fonction LAG pour faire cela, mais je ne sais pas comment l'utiliser. J'utilise DB 12.1.

    Bien cordialement,
    Christian

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 134
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 134
    Par défaut
    La valeur de mv_cout_carburant.kilometrage est bien regroupée par année dans la sous-requête s.
    Il faudrait que tu expliques plus en détail ce qui ne fonctionne pas dans ta requête pour qu'on puisse t'aider à la corriger.
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  3. #3
    Membre Expert
    Homme Profil pro
    Inscrit en
    Septembre 2006
    Messages
    2 963
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2006
    Messages : 2 963
    Par défaut
    le nombre de km de l'année devrait être :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    km - lag(km,1,0) over(order by year1)

  4. #4
    Membre confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2016
    Messages
    199
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Juillet 2016
    Messages : 199
    Par défaut
    J'ai créé cette requête mails elle affiche null pour la première année alors que cela devrait être 7406 km :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    with r as (select kilometrage km, date1 annee from mv_cout_carburant where vehicule = 124 )
    select annee, km, km - LAG (km,1) over (order by annee) annual_km from r;
    Nom : Snap 2020-10-07 at 11.30.40.png
Affichages : 448
Taille : 4,5 Ko

    De plus je voudrai grouper par année. je ne sais pas comment faire.
    Bien cordialement,
    Christian

  5. #5
    McM
    McM est déconnecté
    Expert confirmé

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Billets dans le blog
    4
    Par défaut
    Il manque le 3ème paramètre de lag donné par JeitEmgie pour mettre 0 et éviter d'avoir un NULL sur ton calcul

  6. #6
    Membre confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2016
    Messages
    199
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Juillet 2016
    Messages : 199
    Par défaut
    J'ai modifié la reqûete comme indiqué et elle fonctionne bien, cependant je n'arrive pas à grouper par année.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    with r as (select kilometrage km, date1 annee from mv_cout_carburant where vehicule = 124 )
    select annee, km - LAG (km,1,0) over (order by annee) annual_km from r ;
    Nom : Snap 2020-10-07 at 11.51.38.png
Affichages : 438
Taille : 3,8 Ko
    Images attachées Images attachées  

  7. #7
    McM
    McM est déconnecté
    Expert confirmé

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Billets dans le blog
    4
    Par défaut
    Houla, en fait tu te compliques la vie, je n'avais pas regardé la première requête. Il faut faire plus simple et englober les résultats au fur et à mesure des calculs
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    SELECT year1, cout_carburant1, km, cout_carburant1+NVL(montant_facture1,0) "carburant+factures", NVL(montant_facture1,0) "Factures",
    					ROUND ( (cout_carburant1+NVL(montant_facture1,0)) /  KM, 3) "PRK"
    FROM (
        SELECT EXTRACT(YEAR FROM date1) AS year1, SUM(cout_carburant) AS cout_carburant1, SUM(kilometrage) AS km,
              (SELECT SUM(NVL(t.montant_facture,0)) 
              FROM mv_entretien t WHERE t.vehicule= c.vehicule
              AND EXTRACT(YEAR FROM t.date_travaux) = EXTRACT(YEAR FROM c.date1) ) AS montant_facture1 
        FROM mv_cout_carburant c
        WHERE vehicule = :P13_VEHICULE 
        GROUP BY TRUNC(date1, 'YYYY') 
        )
    ORDER BY 1
    PS : j'ai mis des Extract(year from ...) afin d'avoir juste l'année

    PS2 : Attention, s'il y a des travaux une année alors qu'il n'y a pas de Km cette année là, tu ne verras pas la ligne de travaux
    Tu peux vérifier avec ce code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    select vehicule, trunc(date_travaux, 'YYYY') from  mv_entretien
    MINUS
    select vehicule, trunc(date1, 'YYYY') from  mv_cout_carburant

Discussions similaires

  1. Réponses: 1
    Dernier message: 18/01/2018, 12h31
  2. [XL-2010] Calculer les vacances d'appartement dans une année spécifique
    Par Loudelune dans le forum Excel
    Réponses: 1
    Dernier message: 12/10/2017, 01h39
  3. Réponses: 2
    Dernier message: 10/12/2013, 17h02
  4. Réponses: 5
    Dernier message: 24/08/2009, 08h14
  5. [MFC]Calculer les FPS
    Par inerti@ dans le forum MFC
    Réponses: 6
    Dernier message: 19/03/2003, 18h22

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