Solved

Sql Server query conditional SUM

Posted on 2012-03-26
6
565 Views
Last Modified: 2012-03-27
I have this query but instead return "valorliquido" field (in my actual query), i need return in each mount the following:

SUM(CASE WHEN TipoDoc <> 'NC' AND Anulado = 0 THEN valorliquido  END) - SUM(CASE WHEN TipoDoc = 'FC' AND Anulado = 0 THEN valorliquido  END)

How can do it.


My actual query:

SELECT year(DataDocumento) As 'Ano',

SUM(CASE month(DataDocumento) WHEN 1 THEN valorliquido ELSE 0 END) AS 'Jan',

SUM(CASE month(DataDocumento) WHEN 2 THEN valorliquido ELSE 0 END) AS 'Fev',

SUM(CASE month(DataDocumento) WHEN 3 THEN valorliquido ELSE 0 END) AS 'Mar',

SUM(CASE month(DataDocumento) WHEN 4 THEN valorliquido ELSE 0 END) AS 'Abr',

SUM(CASE month(DataDocumento) WHEN 5 THEN valorliquido ELSE 0 END) AS 'Mai',

SUM(CASE month(DataDocumento) WHEN 6 THEN valorliquido ELSE 0 END) AS 'Jun',

SUM(CASE month(DataDocumento) WHEN 7 THEN valorliquido ELSE 0 END) AS 'Jul',

SUM(CASE month(DataDocumento) WHEN 8 THEN valorliquido ELSE 0 END) AS 'Ago',

SUM(CASE month(DataDocumento) WHEN 9 THEN valorliquido ELSE 0 END) AS 'Set',

SUM(CASE month(DataDocumento) WHEN 10 THEN valorliquido ELSE 0 END) AS 'Out',

SUM(CASE month(DataDocumento) WHEN 11 THEN valorliquido ELSE 0 END) AS 'Nov',

SUM(CASE month(DataDocumento) WHEN 12 THEN valorliquido ELSE 0 END) AS 'Dez'

FROM cabft WHERE year(DataDocumento) >= 2010
GROUP by year(DataDocumento)
0
Comment
Question by:rflorencio
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 4
  • 2
6 Comments
 
LVL 74

Expert Comment

by:sdstuber
ID: 37766633
since you are already summing,  I don't think you really need the inner sum too, just put the cases within existing sum case



SELECT   year(datadocumento) AS 'Ano',
         SUM(
             CASE month(datadocumento)
                 WHEN 1
                 THEN
                       CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido END
                     - CASE WHEN tipodoc = 'FC' AND anulado = 0 THEN valorliquido END
                 ELSE
                     0
             END)
             AS 'Jan',
         SUM(
             CASE month(datadocumento)
                 WHEN 2
                 THEN
                       CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido END
                     - CASE WHEN tipodoc = 'FC' AND anulado = 0 THEN valorliquido END
                 ELSE
                     0
             END)
             AS 'Fev',
         SUM(
             CASE month(datadocumento)
                 WHEN 3
                 THEN
                       CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido END
                     - CASE WHEN tipodoc = 'FC' AND anulado = 0 THEN valorliquido END
                 ELSE
                     0
             END)
             AS 'Mar',
         SUM(
             CASE month(datadocumento)
                 WHEN 4
                 THEN
                       CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido END
                     - CASE WHEN tipodoc = 'FC' AND anulado = 0 THEN valorliquido END
                 ELSE
                     0
             END)
             AS 'Abr',
         SUM(
             CASE month(datadocumento)
                 WHEN 5
                 THEN
                       CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido END
                     - CASE WHEN tipodoc = 'FC' AND anulado = 0 THEN valorliquido END
                 ELSE
                     0
             END)
             AS 'Mai',
         SUM(
             CASE month(datadocumento)
                 WHEN 6
                 THEN
                       CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido END
                     - CASE WHEN tipodoc = 'FC' AND anulado = 0 THEN valorliquido END
                 ELSE
                     0
             END)
             AS 'Jun',
         SUM(
             CASE month(datadocumento)
                 WHEN 7
                 THEN
                       CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido END
                     - CASE WHEN tipodoc = 'FC' AND anulado = 0 THEN valorliquido END
                 ELSE
                     0
             END)
             AS 'Jul',
         SUM(
             CASE month(datadocumento)
                 WHEN 8
                 THEN
                       CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido END
                     - CASE WHEN tipodoc = 'FC' AND anulado = 0 THEN valorliquido END
                 ELSE
                     0
             END)
             AS 'Ago',
         SUM(
             CASE month(datadocumento)
                 WHEN 9
                 THEN
                       CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido END
                     - CASE WHEN tipodoc = 'FC' AND anulado = 0 THEN valorliquido END
                 ELSE
                     0
             END)
             AS 'Set',
         SUM(
             CASE month(datadocumento)
                 WHEN 10
                 THEN
                       CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido END
                     - CASE WHEN tipodoc = 'FC' AND anulado = 0 THEN valorliquido END
                 ELSE
                     0
             END)
             AS 'Out',
         SUM(
             CASE month(datadocumento)
                 WHEN 11
                 THEN
                       CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido END
                     - CASE WHEN tipodoc = 'FC' AND anulado = 0 THEN valorliquido END
                 ELSE
                     0
             END)
             AS 'Nov',
         SUM(
             CASE month(datadocumento)
                 WHEN 12
                 THEN
                       CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido END
                     - CASE WHEN tipodoc = 'FC' AND anulado = 0 THEN valorliquido END
                 ELSE
                     0
             END)
             AS 'Dez'
    FROM cabft
   WHERE year(datadocumento) >= 2010
GROUP BY year(datadocumento)
0
 

Author Comment

by:rflorencio
ID: 37767235
When run query with:

 CASE WHEN tipodoc = 'NC' AND anulado = 0 THEN valorliquido END

returns zero, but if this line is supressed the value is correct.


SUM(
             CASE month(datadocumento)
                 WHEN 1
                 THEN
                       CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido END
                     -- CASE WHEN tipodoc = 'NC' AND anulado = 0 THEN valorliquido END
                 ELSE
                     0
             END)
             AS 'Jan',
0
 
LVL 74

Expert Comment

by:sdstuber
ID: 37767241
and if it is not commented out, what happens?
0
Optimize your web performance

What's in the eBook?
- Full list of reasons for poor performance
- Ultimate measures to speed things up
- Primary web monitoring types
- KPIs you should be monitoring in order to increase your ROI

 

Author Comment

by:rflorencio
ID: 37767300
If is not commented return zero, if commented return the correct value.
0
 
LVL 74

Expert Comment

by:sdstuber
ID: 37767325
I don't understand if it returns 0,  then subtracting it from the other case should return whatever the other case returns.
0
 
LVL 74

Accepted Solution

by:
sdstuber earned 500 total points
ID: 37767342
ooops! I think I figured it out,  I took the queries too literally


SELECT   year(datadocumento) AS 'Ano',
         SUM(
             CASE month(datadocumento)
                 WHEN 1
                 THEN
                         CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido
                      WHEN tipodoc = 'FC' AND anulado = 0 THEN -1 * valorliquido END
                 ELSE
                     0
             END)
             AS 'Jan',
         SUM(
             CASE month(datadocumento)
                 WHEN 2
                 THEN
                         CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido
                      WHEN tipodoc = 'FC' AND anulado = 0 THEN -1 * valorliquido END
                 ELSE
                     0
             END)
             AS 'Fev',
         SUM(
             CASE month(datadocumento)
                 WHEN 3
                 THEN
                         CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido
                      WHEN tipodoc = 'FC' AND anulado = 0 THEN -1 * valorliquido END
                 ELSE
                     0
             END)
             AS 'Mar',
         SUM(
             CASE month(datadocumento)
                 WHEN 4
                 THEN
                        CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido
                      WHEN tipodoc = 'FC' AND anulado = 0 THEN -1 * valorliquido END
                 ELSE
                     0
             END)
             AS 'Abr',
         SUM(
             CASE month(datadocumento)
                 WHEN 5
                 THEN
                         CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido
                      WHEN tipodoc = 'FC' AND anulado = 0 THEN -1 * valorliquido END
                 ELSE
                     0
             END)
             AS 'Mai',
         SUM(
             CASE month(datadocumento)
                 WHEN 6
                 THEN
                         CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido
                      WHEN tipodoc = 'FC' AND anulado = 0 THEN -1 * valorliquido END
                 ELSE
                     0
             END)
             AS 'Jun',
         SUM(
             CASE month(datadocumento)
                 WHEN 7
                 THEN
                         CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido
                      WHEN tipodoc = 'FC' AND anulado = 0 THEN -1 * valorliquido END
                 ELSE
                     0
             END)
             AS 'Jul',
         SUM(
             CASE month(datadocumento)
                 WHEN 8
                 THEN
                         CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido
                      WHEN tipodoc = 'FC' AND anulado = 0 THEN -1 * valorliquido END
                 ELSE
                     0
             END)
             AS 'Ago',
         SUM(
             CASE month(datadocumento)
                 WHEN 9
                 THEN
                        CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido
                      WHEN tipodoc = 'FC' AND anulado = 0 THEN -1 * valorliquido END
                 ELSE
                     0
             END)
             AS 'Set',
         SUM(
             CASE month(datadocumento)
                 WHEN 10
                 THEN
                      CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido
                      WHEN tipodoc = 'FC' AND anulado = 0 THEN -1 * valorliquido END
                 ELSE
                     0
             END)
             AS 'Out',
         SUM(
             CASE month(datadocumento)
                 WHEN 11
                 THEN
                       CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido
                      WHEN tipodoc = 'FC' AND anulado = 0 THEN -1 * valorliquido END
                 ELSE
                     0
             END)
             AS 'Nov',
         SUM(
             CASE month(datadocumento)
                 WHEN 12
                 THEN
                       CASE WHEN tipodoc <> 'NC' AND anulado = 0 THEN valorliquido
                      WHEN tipodoc = 'FC' AND anulado = 0 THEN -1 * valorliquido END
                 ELSE
                     0
             END)
             AS 'Dez'
    FROM cabft
   WHERE year(datadocumento) >= 2010
GROUP BY year(datadocumento)
0

Featured Post

Online Training Solution

Drastically shorten your training time with WalkMe's advanced online training solution that Guides your trainees to action. Forget about retraining and skyrocket knowledge retention rates.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Load balancing is the method of dividing the total amount of work performed by one computer between two or more computers. Its aim is to get more work done in the same amount of time, ensuring that all the users get served faster.
This article shows gives you an overview on SQL Server 2016 row level security. You will also get to know the usages of row-level-security and how it works
This video shows how to set up a shell script to accept a positional parameter when called, pass that to a SQL script, accept the output from the statement back and then manipulate it in the Shell.
Via a live example, show how to extract insert data into a SQL Server database table using the Import/Export option and Bulk Insert.

632 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question