현재 계산 된 멤버를 사용하여 고객이 처음 판매 한 판매 금액을 반환하려고합니다. 나는 약간의 코드를 사용하여 다양한 블로그를 살펴 보았지만 찾고있는 결과 세트와 일치하는 방식으로이를 적용하는 데 몇 가지 문제가 발생했습니다.첫 번째 판매 금액을 얻는 MDX
계산 된 여러 멤버를 만들려고합니다. 하나는 특정 제품의 첫 주문 날짜를 반환하는 것입니다. 나는 지금 그 날짜를 가져 와서 그 날의 그 제품의 판매만을 돌려주고 싶습니다. 이것은 현재 날짜 축을 방정식에 넣을 때마다 문제가 발생하는 곳입니다. 계층 구조의 요일 수준에 있지 않으면 CurrentMember 함수가 어떤 수준으로 집계되어 일부 불일치가 발생합니다.
여기에 내가 (우리의 마지막 처리 시간입니다) 전날의 일 수준에서의 WHERE 절을 넣을 경우이 코드는 작동 현재
WITH
MEMBER [Measures].[DaysToDate] AS
COUNT(NULL:[Date].[Fiscal].CURRENTMEMBER)
MEMBER [Measures].[HadSale] AS
IIF([Measures].[Product Sales]=0,NULL,[Measures].[DaysToDate])
MEMBER [Measures].[MinDate] AS
MIN(NULL:[Date].[Fiscal].CURRENTMEMBER, [Measures].[HadSale])
MEMBER [Measures].[FirstSaleDay] AS
IIF(ISEMPTY([Measures].[MinDate]), NULL,
[Date].[Fiscal].[Day].MEMBERS.ITEM([Measures].[MinDate]).NAME)
SELECT {
[Measures].[DaysToDate]
,[Measures].[HadSale]
,[Measures].[MinDate]
,[Measures].[FirstSaleDay]
} ON 0,
[Sales Team].[Sales Team].[Customer].MEMBERS ON 1
FROM [Sales and Marketing]
무슨의 일반입니다. 그러나 제가 회계 연도라고 말하면, 일보다 높은 레벨 인 칼럼에 배치하면 Days 대신 Quarters를 기준으로 CurrentMembers를 계산하고 내부의 통과로 인해 잘못된 일을 반환합니다. [FirstSaleDay]의 ITEM().
저는 대부분이 계층 구조의 어떤 레벨이 최종 쿼리에 전달되는 것과 대조적으로 이러한 계산이 하루 수준에서 작동하도록하는 방법을 찾고 있습니다.
도움을 주시면 감사하겠습니다.