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

Développement SQL Server Discussion :

CA CLIENT SUR 2 ANNÉES


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Futur Membre du Club
    Inscrit en
    Avril 2009
    Messages
    3
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 3
    Par défaut CA CLIENT SUR 2 ANNÉES
    je suis sur une base SQL SERVER 2000. Je dois réalisé le ca des clients sur une période donnée avec période -1.

    J'ai une table f_docligne ou j'ai toutes les lignes des factures avec code client, date,montant etc.......
    et f_comptet ou je récupère l'intitulé du compte

    J'ai réalisé le code ci dessous, par contre je n'arrive pas à faire une requête qui me permette d'avoir la période et la période-1 côte à côte.


    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
    SELECT   a.ct_num,  b.ct_intitule, SUM(a.DL_MontantHT) as CA
    
    FROM         F_DOCLIGNE AS a  
    RIGHT JOIN F_COMPTET AS b
    
    ON a.ct_num = b.ct_num
    
    where  a.dl_datebl between '01/08/2008' and '30/04/2009'
    and a.ct_num like 'c%' and a.do_piece like 'fa%'
    	
    group by    a.CT_Num, b.ct_intitule
    
    
    SELECT   c.ct_num, d.ct_intitule, SUM(c.DL_MontantHT) as BA
    
    FROM         F_DOCLIGNE AS c 
    
    RIGHT JOIN F_COMPTET AS d
    
    on c.ct_num = d.ct_num
    
    where  c.dl_datebl between '01/08/2007' and '30/04/2008'
    
    and c.ct_num like 'c%' and c.do_piece like 'fa%'
    
    
    		
    group by    c.CT_Num,d.ct_intitule

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    22 001
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 22 001
    Billets dans le blog
    6
    Par défaut
    Quelque chose comme :

    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
    SELECT a.ct_num, b.ct_intitule, SUM(a.DL_MontantHT) as CA,
           (SELECT  SUM(cin.DL_MontantHT)
            FROM    F_DOCLIGNE AS cin
                    RIGHT OUTER JOIN F_COMPTET AS din
                          on cin.ct_num = din.ct_num
            where   cin.dl_datebl between '01/08/2007' and '30/04/2008'
              and   cin.ct_num = ain.ct_num 
              and   cin.do_piece = aout.do_piece) AS PRECEDENT_CA
    FROM   F_DOCLIGNE AS aout
           RIGHT OUTERJOIN F_COMPTET AS bout
                 ON aout.ct_num = bout.ct_num
    WHERE  aout.dl_datebl between '01/08/2008' and '30/04/2009'
    and    aout.ct_num like 'c%' 
    and    aout.do_piece like 'fa%'
    group by a.CT_Num, b.ct_intitule
    Bref, sous requête corrélées dans la clause SELECT.

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  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
    Je le verai un peu plus simple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    SELECT a.ct_num, b.ct_intitule,
           SUM ( CASE WHEN a.dl_datebl BETWEEN '01/08/2008' AND '30/04/2009' THEN a.DL_MontantHT ELSE 0 END ) AS CA,
           SUM ( CASE WHEN a.dl_datebl BETWEEN '01/08/2007' AND '30/04/2008' THEN a.DL_MontantHT ELSE 0 END ) AS PRECEDENT_CA
    FROM   F_DOCLIGNE AS a
           RIGHT OUTER JOIN F_COMPTET AS b
             ON a.ct_num = b.ct_num
    WHERE (a.dl_datebl BETWEEN '01/08/2007' AND '30/04/2008'
     OR    a.dl_datebl BETWEEN '01/08/2008' AND '30/04/2009')
    AND    a.ct_num LIKE 'c%' 
    AND    a.do_piece LIKE 'fa%'
    GROUP BY a.CT_Num, b.ct_intitule

Discussions similaires

  1. Réponses: 0
    Dernier message: 23/03/2010, 11h45
  2. Réponses: 4
    Dernier message: 25/11/2005, 18h15
  3. Filtrer un formulaire sur l'année
    Par Farbin dans le forum Access
    Réponses: 2
    Dernier message: 22/10/2005, 10h14
  4. [JS] Evénement client sur un controle ASP
    Par Coplan dans le forum ASP.NET
    Réponses: 6
    Dernier message: 26/05/2005, 17h31
  5. requête sur l'année d'une date
    Par jo77 dans le forum Langage SQL
    Réponses: 4
    Dernier message: 30/07/2003, 09h28

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