Odd GROUP BY output DB2 - Results not as expected

Posted by CallCthulhu on Stack Overflow See other posts from Stack Overflow or by CallCthulhu
Published on 2009-11-19T09:35:41Z Indexed on 2010/03/30 11:03 UTC
Read the original article Hit count: 352

Filed under:
|
|

If I run the following query:


select  load_cyc_num
,  crnt_dnlq_age_cde
,  sum(cc_min_pymt_amt) as min_pymt
,  sum(ec_tot_bal) as budget
,  case when ec_tot_bal > 0 then 'Y' else 'N' end as budget
,  case when ac_stat_cde in ('A0P','A1P','ARP','A3P') then 'Y' else 'N' end as arngmnt
,  sum(sn_close_bal) as st_bal
from  statements
where  (sn_close_bal > 0 or ec_tot_bal > 0)
and  load_cyc_num in (200911)
group by  load_cyc_num
,  crnt_dnlq_age_cde
,  case when ec_tot_bal > 0 then 'Y' else 'N' end 
,  case when ac_stat_cde in ('A0P','A1P','ARP','A3P') then 'Y' else 'N' end

then I get the correct "BUDGET" grouping, but not the correct "ARRANGEMENT" grouping, only two rows have a "Y".

If I change the order of the case statements in the GROUP BY, then I get the correct grouping (full Y-N breakdown for both columns).

Am I missing something obvious?

© Stack Overflow or respective owner

Related posts about sql

Related posts about db2