Solved

Sql Server query conditional SUM

Posted on 2012-03-26
6
562 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
Free learning courses: Active Directory Deep Dive

Get a firm grasp on your IT environment when you learn Active Directory best practices with Veeam! Watch all, or choose any amount, of this three-part webinar series to improve your skills. From the basics to virtualization and backup, we got you covered.

 

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

Microsoft Certification Exam 74-409

Veeam® is happy to provide the Microsoft community with a study guide prepared by MVP and MCT, Orin Thomas. This guide will take you through each of the exam objectives, helping you to prepare for and pass the examination.

Question has a verified solution.

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

Suggested Solutions

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.
The Delta outage: 650 cancelled flights, more than 1200 delayed flights, thousands of frustrated customers, tens of millions of dollars in damages – plus untold reputational damage to one of the world’s most trusted airlines. All due to a catastroph…
Via a live example, show how to set up a backup for SQL Server using a Maintenance Plan and how to schedule the job into SQL Server Agent.
Via a live example, show how to shrink a transaction log file down to a reasonable size.

740 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