Here is a simple example, which involves one of the most common "brick walls" hit by new MDX writers. You want to write a query that would be the logical equivalent of
with member [Client Host].[Client Geography].ANZ as
sum({[Client Host].[Client Geography].[Region].&[Asia].[AUSTRALIA],
[Client Host].[Client Geography].[Region].&[Asia].[NEW ZEALAND]})
select
{measures.hits,measures.sessions,Measures.[bytes total]} on 0,
tail([Date].[Year Month Day].[Month],12) on 1
from [EasternMining]
where [Client Host].[Client Geography].ANZdata:image/s3,"s3://crabby-images/9b716/9b716a3dd1b1bc7b0f5867fc429a6767ae727f81" alt=""
sum({[Client Host].[Client Geography].[Region].&[Asia].[AUSTRALIA],
[Client Host].[Client Geography].[Region].&[Asia].[NEW ZEALAND]})
select
{measures.hits,measures.sessions,Measures.[bytes total]} on 0,
tail([Date].[Year Month Day].[Month],12) on 1
from [EasternMining]
where [Client Host].[Client Geography].ANZ
Here is another way to write exactly the same query
select
{measures.hits,measures.sessions,Measures.[bytes total]} on 0,
tail([Date].[Year Month Day].[Month],12) on 1
from
(select {[Client Host].[Client Geography].[Region].&[Asia].[AUSTRALIA],
[Client Host].[Client Geography].[Region].&[Asia].[NEW ZEALAND]} on 0
from [EasternMining])
Of course there are many other ways of expressing this same query. I would not suggest that you should use one technique over the other. It really depends on which one is easier to read, easier to maintain, and runs faster.data:image/s3,"s3://crabby-images/64f17/64f17b320c1a67f9f1e0370ef9b74d8d7d663c82" alt=""
For online real-time OLAP and data mining demonstrations goto http://RichardLees.com.au/Sites/Demonstrations
2 comments:
my MDX is a bit rusty, but couldn't you simply add those 2 regions into the WHERE clause?
Here are this and some other articles about MDX:
http://ssas-wiki.com/w/Articles#About_MDX
Post a Comment