- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在构建一个模型,以允许报告两个单独的数据集,在本例中,我们称学生数据集和员工数据集。
数据集非常独立,两者之间唯一真正的联系是日期,因此从模型的角度来看,有一个学生星型模式和一个员工星型模式。
显示的数据是快照类型数据,回答如下问题:- 对于选定的日期,显示所有在职员工- 对于选定的日期,显示所有注册的学生
这意味着,当选择单个日期时,模型会查找所选日期在就业开始和结束日期内的所有员工,并查找所选日期在注册开始和结束日期内的所有学生。
这意味着我必须做出决定,如何使用单个日期维度从每个模式返回正确的数据。创建关系不起作用,因为表格中的关系不允许“之间”类型查询,因此我有一个不相关的日期维度,并且每个模型的 Dax 都会找到适用的行。
问题是它不是性能最好的。对于大约 50k 行,添加度量可能需要 5-10 秒。
我问是否有更好的方法来编写查询,或者更改模型以仍然让我执行“之间”样式查询,但提供更好的性能。
下面是一个 dax 查询示例,用于返回在特定日期注册的所有学生。
感谢您的建议。
All Enrolled Students:=IF (
HASONEVALUE ( 'Date'[Date] ),
CALCULATE (
DISTINCTCOUNT ( 'Students'[StudentID] ),
FILTER (
'Students',
'Students'[StudentStartDateID] <= MIN ( 'Date'[DateID] )
&& 'Students'[StudentEndDateID] >= MAX ( 'Date'[DateID] )
)
),
BLANK ())
最佳答案
在某些情况下,不相关或“断开连接”的表非常适合为切片器、时间线和过滤器提供支持。正如您在问题中所说,您有两个优化选项:重新构建数据集或优化现有的度量语法。
复制开始日期和结束日期之间每一天的每一行,并有一列表示该迭代日期。这可以通过多种方式完成,具体取决于您获取数据集的方式,但可能很乏味。然后,将表与该迭代日期相关联,并使用该关系从“日期”过滤到“事实”。如果这是一个定期报告和/或您使用 SQL 来提取数据,那么利用 PowerPivot 的关系计算能力可能是值得的。
如果这是一次性请求,或者数据集太繁琐而无法每天复制,那么请坚持使用断开连接的表方法并清理度量语法。由于您已经包含了 MIN() 和 MAX() 函数,并且您的 CALCULATE() 返回 DISTINCTCOUNT(),因此条件 HASONEVALUE() 函数是不必要的。我在模拟环境中运行了此程序并获得了良好的结果,但这可能会因计算机性能和数据集大小而异。请参阅下面的清理语法。
All Enrolled Students:=CALCULATE (
DISTINCTCOUNT('Students'[StudentID]),
FILTER(
'Students',
'Students'[StudentStartDateID]<= MIN('Date'[DateID]) &&
'Students'[StudentEndDateID] >= MAX('Date'[DateID])
)
)
如果您的 StudentID 列是唯一的,这对我来说有意义,您可以进一步加快速度。
All Enrolled Students:=CALCULATE (
COUNT('Students'[StudentID]),
FILTER(
'Students',
'Students'[StudentStartDateID]<= MIN('Date'[DateID]) &&
'Students'[StudentEndDateID] >= MAX('Date'[DateID])
)
)
如果 StudentID 不是数字,请将 COUNT() 替换为 COUNTA() 以获得所需的效果。
关于data-modeling - 优化 "where date between"类型查询的 Dax 和模型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39406861/
数据框有一个字符串类型的日期列 '2017-01-01' 它被转换为 DateType() df = df.withColumn('date', col('date_string').cast(Dat
这个问题在这里已经有了答案: What is "x && foo()"? (5 个答案) 关闭 8 年前。 我在 bootstrap-datepicker.js 文件中遇到过这个。 作者在_setD
我有一个数据库 utc 字符串,我正在传递到 Date(attrs.endDate),然后通过 new Date() 减去当前的 utc 日期,但我无法得到它来为我提供 2 个 utc 日期的正确差异
这个问题在这里已经有了答案: how to determine if 2 dates object equals each other? [duplicate] (3 个答案) 关闭 6 年前。 我
这个问题已经有答案了: How can I convert "/Date(1399739515000)/" into date format in JavaScript? (3 个回答) 已关闭 8
根据MDN ,我们只能将以下类型的参数传递给 Date 构造函数: new Date(); new Date(value); // Unix timestamp new Date(dateString
我从表中获取所有项目: endDate >= 现在 endDate 为 NULL published 等于 1。 这是我所拥有的,但它给了我 0 个项目: $items = Items::orderB
此查询需要很长时间才能完成。当我将 WHERE 子句设置为 new_dl >= '2014-01-01' 时,查询大约需要 6 分钟才能浏览大约 3 个月的数据。现在不知道为什么这个应该从 12 个月
我有一个正在为项目开发的小型 Java 程序,它使用 JavaMail 从指定的 URI 中提取用户的收件箱,然后开始处理消息。 在 Outlook 中,属性菜单中有一个功能可以设置邮件的到期日期,它
我想在获取 Date.getHours()、Date.getMinutes() 和 Date.getSeconds() 的值后格式化输出>. 这是一条漫长的路: var dt = new Date()
我发现java.text.DateFormat有两种格式化日期的方法。一种是采用 Date 参数,另一种是采用 Object 参数。我检查了DateFormat源代码,似乎他们调用了不同的内部方法。
我有两个对象,p4 和 p5,它们都具有 Date 属性。在某些时候,构造函数工作正常: p4.setClickDate(new Date(System.currentTimeMillis() - 8
我是使用 Sequelize 和 Node.js 的新手,但我的代码中存在日期比较问题。 User.findOne({ where: { resetToken: passwordToken,
我正在使用一个名为 fullcalendar 的 jquery 日历。当用户单击某一天时,他们将被发送到另一个页面以创建该天的事件。单击的日期作为 date 提供。然后通过下面的函数运行将其转换为 U
我有一个列表列表,每个列表中都有整数值,代表 8 年期间的日期。 dates = [[2014, 11, 14], [2014, 11, 13], ....., [2013, 12, 01]
我有两个表: 首先是TimeValues(示例) time | value 12/28/18 | 5.6 01/03/19 | 5.6 01/04/19 | 5.6 01/09/19 | 5.
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and th
像这样实例化的日期对象: new Date("2011-12-13") 返回一个认为自己是星期一的日期对象: Date {Mon Dec 12 2011 16:00:00 GMT-0800 (PST)
我需要选择入住日期和退房日期在指定日期范围之间的房价。这些费率根据其条件单独命名。房费取决于所选日期。这是我的代码: rate_eb rate_name rate_starts rat
我有 [Int64:[String:String]] 其中 Int64 是时间戳。如何检测和删除 [String:String] 中的参数之一是 ["name"] = "test" 并重复多次的同一天
我是一名优秀的程序员,十分优秀!