These are really hard to describe without going in-depth into the data structure, i'll try to keep it as short as possible while giving as much info as I can.
I have a measure which is a monetary value over time (cashflow), along with dimensions for date, and one for valuation. A valuation has a date, and this date would correspond with the first cashflow date.
The gist of what im after is the first value (or in other words the cashflow value corresponding with the valuation date. If I know the valuation date, it is easy enough to turn this date into the Date dimension to get me the value im after:
WITH MEMBER [Measures].[Value at Valuation Date]
AS
(
[Measures].[Value],
[Date].[Date].&[2009-09-30T00:00:00]
)
However, if I have a set of valuation dates (say, im trying to get the value at valuation date for 3 month's wort of valuations) this method breaks down, as earlier valuation would have a value corresponding with the date of a later valuation.
So for example this calculated member will return the wrong values:
WITH MEMBER [Measures].[Value at Valuation Date]
AS
(
[Measures].[Value],
{[Valuation.[Valuation Date].&[2009-07-31T00:00:00]:[Valuation].[Valuation Date].&[2009-09-30T00:00:00]}
)
In this example, there are 3 valuations (end of july, aug & sept), each with monthly cashflow values going forward (on the month ends) from the corresponding valuation date. Rather than return me the first cashflow value for each valuation, this gets a sum of all cashflow values which happen to correspond to a valuation date.
I hope this is clear enough to start some discussion of this problem. In case its useful, this is a SQL query that would get the right data from my cube staging database:
SELECT
v.valuationDate,
SUM(cf.value) as [value at valuation date]
FROM dbo.Valuation v
INNER JOIN dbo.Cashflow cf
ON v.id = cf.valuationId
and v.valuationDate = cf.cashflowDate
GROUP BY v.valuationDate
Thanks