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

Langage SQL Discussion :

Trimestre et année


Sujet :

Langage SQL

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Août 2008
    Messages
    77
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : Belgique

    Informations forums :
    Inscription : Août 2008
    Messages : 77
    Points : 53
    Points
    53
    Par défaut Trimestre et année
    Bonjour!

    J'ai un petit soucis!
    Imagineons que j'ai une table qui contient des établissements et une table qui contient des périodes.

    Citation Envoyé par ETABLISSEMENT
    ID
    NOM
    Citation Envoyé par PERIODE
    ANNEE
    TRIMESTRE
    ETABLISSEMENT_FK
    Citation Envoyé par Données ETABLISSEMENT
    -----ID-----NOM-------
    ------1-----AAA-------
    ------2-----BBB-------
    ------3-----CCC-------
    ------4-----DDD-------
    ------5-----EEE-------
    Citation Envoyé par Données PERIODE
    -----ANNEE-----TRIMESTRE-----ETABLISSEMENT_FK------MONTANT--------
    -----2009--------3----------------1-------------------18----------
    -----2009--------2----------------1-------------------36----------
    -----2009--------1----------------1-------------------58----------
    -----2008--------4----------------1-------------------142---------
    -----2008--------3----------------1-------------------68----------
    -----2008--------2----------------1-------------------34----------
    -----2009--------4----------------2-------------------20----------
    -----2009--------3----------------2-------------------26----------
    Mon but est de récupérer le MONTANT d'un établissement précis à la dernière situation. Dans ce cas-ci, c'est au 3ème trimestre 2009 pour AAA.
    Je bloque sur la manière de trouver la situation la plus récente quand il s'agit de trimestre/année.
    Quelqu'un aurait une idée?

    Citation Envoyé par Affichage
    -----NOM-----MONTANT-----
    -----AAA-------18--------
    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
     
    WITH ETABLISSEMENT(ID, NOM) AS
    (
    SELECT '1', 'AAA' union ALL
    SELECT '2', 'BBB' union ALL
    SELECT '3', 'CCC' union ALL
    SELECT '4', 'DDD' union ALL
    SELECT '5', 'EEE' 
    )
    ,  PERIODE (ANNEE, TRIMESTRE, ETABLISSEMENT_FK, MONTANT) AS
    (
    SELECT '2009', '3', '1', 18 union ALL
    SELECT '2009', '2', '1', 36 union ALL
    SELECT '2009', '1', '1', 58 union ALL
    SELECT '2008', '4', '1', 142 union ALL
    SELECT '2008', '3', '1', 68 union ALL
    SELECT '2008', '2', '1', 34 union ALL
    SELECT '2009', '4', '2', 20 union ALL
    SELECT '2009', '3', '2', 26
    )
    SELECT ETABLISSEMENT.NOM, PERIODE.ANNEE, PERIODE.TRIMESTRE, PERIODE.MONTANT
    FROM ETABLISSEMENT
    INNER JOIN PERIODE ON PERIODE.ETABLISSEMENT_FK = ETABLISSEMENT.ID
     
    WHERE ETABLISSEMENT.NOM like 'AAA'
    Merci d'avance!

    PS: Mon problème est plus compliqué que cela, mais en ayant une réponse à cette question, ça pourra mieux m'aider.

  2. #2
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    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 453
    Points : 18 386
    Points
    18 386
    Par défaut
    Vous pouvez par exemple utiliser une fonction de fenêtrage :
    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
    28
    29
    30
    31
    32
    33
    34
    35
    36
     
    WITH ETABLISSEMENT(ID, NOM) AS
    (
    SELECT '1', 'AAA' union ALL
    SELECT '2', 'BBB' union ALL
    SELECT '3', 'CCC' union ALL
    SELECT '4', 'DDD' union ALL
    SELECT '5', 'EEE' 
    )
    ,  PERIODE (ANNEE, TRIMESTRE, ETABLISSEMENT_FK, MONTANT) AS
    (
    SELECT '2009', '3', '1',  18 union ALL
    SELECT '2009', '2', '1',  36 union ALL
    SELECT '2009', '1', '1',  58 union ALL
    SELECT '2008', '4', '1', 142 union ALL
    SELECT '2008', '3', '1',  68 union ALL
    SELECT '2008', '2', '1',  34 union ALL
    SELECT '2009', '4', '2',  20 union ALL
    SELECT '2009', '3', '2',  26
    )
      ,  SR (NOM, ANNEE, TRIMESTRE, MONTANT, rn) AS
    (
    SELECT et.NOM, pr.ANNEE, pr.TRIMESTRE, pr.MONTANT,
           row_number() over(partition by et.ID order by pr.ANNEE desc, pr.TRIMESTRE desc)
      FROM ETABLISSEMENT as et
           INNER JOIN PERIODE as pr
             ON pr.ETABLISSEMENT_FK = et.ID
     WHERE et.NOM = 'AAA'
    )
    select NOM, ANNEE, TRIMESTRE, MONTANT
      from SR
     where rn = 1;
     
    NOM  ANNEE TRIMESTRE MONTANT
    ---- ----- --------- -----------
    AAA  2009  3         18

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Août 2008
    Messages
    77
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : Belgique

    Informations forums :
    Inscription : Août 2008
    Messages : 77
    Points : 53
    Points
    53
    Par défaut
    A première vue, ça a l'air correct.
    Merci!

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 02/04/2012, 11h55
  2. [AC-2010] Requete Comparatif trimestre entre deux année
    Par DidoFido dans le forum Access
    Réponses: 0
    Dernier message: 30/11/2010, 02h34
  3. Réponses: 0
    Dernier message: 21/04/2010, 00h07
  4. Réponses: 0
    Dernier message: 28/01/2010, 11h35
  5. Récupérer l'année d'une date
    Par delphim dans le forum Langage SQL
    Réponses: 3
    Dernier message: 15/01/2003, 16h33

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