Average number of records for past 3 fiscal years grouped by fiscal month

Hi Experts:

I need to  count a certain type of order for the past 3 fiscal years breaking the data out by fiscal month.  So the first number would be the average the count of records for Jan 2013, Jan 2012, Jan 2011, and so on.  The database has a table called ORDERS and one called ORDER_DATE

Here is what I came up with for the full set of data:
select count(*) as myCount,
        od.fiscal_month,
        od.fiscal_year
from orders o
INNER JOIN order_date od ON o.datesubmitted = od.caldate 
where od.fiscalyear in (2013,2012,2011)
and o.order_type='Y'
group by od.fiscal_year,od.fiscal_month
order by od.fiscal_month

Open in new window

I get this:
      cnt  fm          fy
        72 01          2011      
        84 01          2012      
        96 01          2013      
        72 02          2011      
        85 02          2012      
        90 02          2013  
and so on for each fiscal month for each of the three fiscal years.

What I really want is the average for each month like this:
   avg  fm  (72+94+96)/3
  84    01  
 82.3  02  (72+85+90)/3

and so on.

I can get the average of ALL, but I want it broken out by fiscal month over the past 3 fiscal years.  

Any ideas?

Thanks!
BreadbakerAsked:
Who is Participating?
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.

sdstuberCommented:
select avg(cnt), fm from
(select count(*) as myCount,
        od.fiscal_month,
        od.fiscal_year
from orders o
INNER JOIN order_date od ON o.datesubmitted = od.caldate
where od.fiscalyear in (2013,2012,2011)
and o.order_type='Y'
group by od.fiscal_year,od.fiscal_month)
group by fm
order by fm

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
awking00Information Technology SpecialistCommented:
select avg(cnt) avg, fm from
(select count(*) over (partition by od.fiscal_month order by od.fiscal_year) cnt, fiscal_month fm
 from orders o inner join order_date od on o.datesubmitted = od.caldate
 where od.fiscal_year between 2011 and 2013
 and o.order_type = 'Y')
BreadbakerAuthor Commented:
Thanks a bunch.. I was very close, but this cleared it up!
sdstuberCommented:
ID: 39765506

is illegal syntax (no group by) and the analytic will produce the incorrect results
you need to maintain the year within the groups/partitions
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.