Solved

Sql Server query conditional SUM

Posted on 2012-03-26
6
561 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
  • 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
Migrating Your Company's PCs

To keep pace with competitors, businesses must keep employees productive, and that means providing them with the latest technology. This document provides the tips and tricks you need to help you migrate an outdated PC fleet to new desktops, laptops, and tablets.

 

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

Ransomware-A Revenue Bonanza for Service Providers

Ransomware – malware that gets on your customers’ computers, encrypts their data, and extorts a hefty ransom for the decryption keys – is a surging new threat.  The purpose of this eBook is to educate the reader about ransomware attacks.

Question has a verified solution.

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

JSON is being used more and more, besides XML, and you surely wanted to parse the data out into SQL instead of doing it in some Javascript. The below function in SQL Server can do the job for you, returning a quick table with the parsed data.
For both online and offline retail, the cross-channel business is the most recent pattern in the B2C trade space.
Via a live example, show how to extract information from SQL Server on Database, Connection and Server properties
Using examples as well as descriptions, and references to Books Online, show the documentation available for datatypes, explain the available data types and show how data can be passed into and out of variables.

789 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