Crystal Report 11 -- Cross Tab format and SQL connect by function

I have a cross-tab with 24 months of data. (Please see the attached file). But sometimes the SQL doesn't return 24 months of data, because there is no data for those months. In our example the Sep 2010 and Oct 2010 (201009 & 201010) doesnt have data. But I want those columns in the report with just 0s as shown in the attachment. i tried using the following SQL, but still not able to acheive the one I want.

The ?DATE_ENTERED is a parameter. If for example today's date is given (11-16-2010), I have a formula[maximum(LastFullMonth)] which makes the date to previous months last date (10-31-2010). So the date range would be from oct 2010 and goes back 24 months nov 2008.
I tried playing with the connect by level number sometimes it goes backward or forward not the right one.
When I run just the second part of the union all, I get the desired result ie., from 11/01/2008 thru 10/01/2010, but when I use it together its not giving the desired result, maybe I dont understand that function fully.

trunc(s_date, 'MM') as SDATE,
trunc(s_date, 'MM') as SDATE,



-- This is to get those months which aren't returned
     trunc({?DATE_ENTERED}, 'mm') + INTERVAL '-1' MONTH * ROWNUM SDATE,
     trunc({?DATE_ENTERED}, 'mm') + INTERVAL '-1' MONTH * ROWNUM PDATE,
    0 AS salary

FROM dual 


Open in new window

My next question is, can we change the label of the summary row, that is, GRAND TOTAL instead of just TOTAL. I have highlighted in red in the attachment.


Who is Participating?

[Product update] Infrastructure Analysis Tool is now available with Business Accounts.Learn More

I wear a lot of hats...

"The solutions and answers provided on Experts Exchange have been extremely helpful to me over the last few years. I wear a lot of hats - Developer, Database Administrator, Help Desk, etc., so I know a lot of things but not a lot about one thing. Experts Exchange gives me answers from people who do know a lot about one thing, in a easy to use platform." -Todd S.

I have done something similar in Crystal - using connect by level, to return all possible dates...

This is basically what I did, and replaced the start (3/1/2008) and end (3/31/2010) with 2 crystal date parameters... I'm sure you can accomplish something similar by using just a single date param.

        trunc(to_date('01-MAR-2008'))-1 + level as cal_date
        from dual
        where (to_date('01-MAR-2008')-1+level) <= to_date('31-mar-2010')
        connect by level<=100000

      select distinct
      {?beginofrange}-1 + level
      from dual
      where ({?beginofrange}-1+level) <= trunc({?endofrange})
      connect by level<=1000

Regarding changing labels, Yes - just select to highlight the field in the cross tab, and his F2 to edit the text.

Experts Exchange Solution brought to you by

Your issues matter to us.

Facing a tech roadblock? Get the help and guidance you need from experienced professionals who care. Ask your question anytime, anywhere, with no hassle.

Start your 7-day free trial
D-pkAuthor Commented:
Thanks LinInDenver!
It's more than this solution.Get answers and train to solve all your tech problems - anytime, anywhere.Try it for free Edge Out The Competitionfor your dream job with proven skills and certifications.Get started today Stand Outas the employee with proven skills.Start learning today for free Move Your Career Forwardwith certification training in the latest technologies.Start your trial today
Oracle Database

From novice to tech pro — start learning today.