Tek-Tips is the largest IT community on the Internet today!

Members share and learn making Tek-Tips Forums the best source of peer-reviewed technical information on the Internet!

  • Congratulations gkittelson on being selected by the Tek-Tips community for having the most helpful posts in the forums last week. Way to Go!

SQL Query - Z/OS DB2 QMF

Status
Not open for further replies.

Rick_McGee

Technical User
Mar 7, 2018
1
US
I inherited a query that needs modifying. The query seems standard with a 'Select field1, field2 from TABLE_A where blah, blah, blah....'

Then it has the following statements as a part of the query:


Code:
HAVING (SUM(CASE                                          
           WHEN S.LVLP1 NOT IN ('A','B','C','D')  THEN 1  
           ELSE 0 END)                                    
     + SUM(CASE                                           
           WHEN S.LVLP1 IN('A','B','C','D') THEN 1        
           ELSE 0 END)                                    
     ¬= SUM(CASE                                          
           WHEN S.LVLP1 NOT IN('A','B','C','D') THEN 1    
           ELSE 0 END))                                   
AND SUM(CASE                                              
       WHEN S.LVLP1 IN('A','B','C','D') THEN 1            
       ELSE 0 END) > 0


I cannot understand what the SUM(CASE) statements are doing. They seem redundant, but it's a query that's been used for sometime. Can someone please shed some light on what these statements are accomplishing? Thank you.
 
That is a standard having clause for a group by select.

but what that is doing is.

based on the group clause
block 1
case 1 - sum 1 for all records where s.lvlp1 is not in a,b,c,d
case 2 - sum 1 for all records where lvlp1 in a,b,c,d
not equal
case 3 - sum 1 for all records where s.lvlp1 is not in a,b,c,d

block 2
case 4 - sum 1 for all records where lvlp1 in a,b,c,d
greater 0 (zero)

so only the records that match this criteria after the group by clause is applied will be selected.

but unless I am misreading the above is a bit redundant.

a + b <> a is only true if b > 0
but having clause is filtering for cases where b > 0 so the first block is always true hence could be removed



Regards

Frederico Fonseca
SysSoft Integrated Ltd

FAQ219-2884
FAQ181-2886
 
Status
Not open for further replies.

Part and Inventory Search

Sponsor

Back
Top