我在 $Monitoring 多维数据集上有以下 MDX 语句:
WITH
MEMBER [Measures].[Unique Users] AS distinctcount(([User].[User].[User L].members
, [Measures].[Open Report Count])),format_string="#,#0"
SELECT
NON EMPTY { {[Measures].[Unique Users],[Measures].[Open Report Count]} } ON COLUMNS,
NON EMPTY { [Time].[Time].[Day L] } ON ROWS
FROM ( SELECT
{ lag(strtomember("[Time].[Time].["+right("0"+str(day(SchemaRefreshTime())),2) +"-"+ right("0"+str(month(SchemaRefreshTime())),2) + "-"+str(year(SchemaRefreshTime()))+ "]"), 6):strtomember("[Time].[Time].["+right("0"+str(day(SchemaRefreshTime())),2) +"-"+ right("0"+str(month(SchemaRefreshTime())),2) + "-"+str(year(SchemaRefreshTime()))+ "]") } ON 0 FROM [$Monitoring])
/*ic3navigation*/
axis 1 NON EMPTY order(nonempty(Descendants([Report].[Report], ,leaves),[Open Report Count]),[Open Report Count],desc)
FILTERBY /*ic3*/ {[Time].[Time].[ALL].&[2015].&[2015-11-27].&[27-11-2015]}
FILTERBY /*ic3*/ {[User].[User].[All Users].&[<user>]}
- *) 更改
<user>
为实际用户名 - *) ...lag.. 公式用于根据架构刷新时间给出最后 7 天
- ***) 如果您已填写现有用户,则此 MDX 查询可以在任何 $Monitoring 多维数据集上运行
我希望 distinctcount 函数考虑到 FILTERBY。所以结果应该是 1(只选择了一个用户)。奇怪的是,它没有。它显示了多个用户,因此我假设用户上的 FILTERBY 没有考虑到 distinctcount。
当我将 FILTER BY 移动到 AXIS 或 ROWS 或 COLUMNS 时,也会发生同样的事情。
这是一个错误还是 MDX/MDX++ 在 icCube 中的工作原理?
请指教。