美文网首页PowerQuery
DAX中LASTDATE()函数引用的日期列不得存在重复日期

DAX中LASTDATE()函数引用的日期列不得存在重复日期

作者: PowerQuery | 来源:发表于2016-06-05 16:32 被阅读564次

在《Power Pivot Alchemy》Page17,作者提到可以在DAX中用LASTDATE获取最新日期:

 [LastRefreshed] = LASTDATE(Sales[TransactionDate])

其中的参数是一个日期列。我照猫画虎,检查公式没有错误,但是拖到值区域,就出现如下提示:


LASTDATE运行时出错

好吧,我知道怎么获取唯一值,于是用了下面的公式:

=LASTDATE(DISTINCT('学习报表-系统'[完成时间]))

但是还是同样的错误,那我再换:

=LASTDATE(VALUES('学习报表-系统'[完成时间]))

没用,还是一样的错误。
试试看用最传统的MAX大法呢:

=MAX('学习报表-系统'[完成时间])

这次一次成功。
现在回头来看错误提示,Excel告诉我是因为引用的日期列中有重复日期,但是我后来用DISTINCT和VALUES都去除重复了呀,这也不行?那我试试看新建一个没有任何重复的日期列在来测试看。

测试数据:日期重复时间不重复

这个测试数据虽然没有重复值,但是有重复日期,所以测试也是失败的。
那我试试看日期也不重复呢:

测试数据:日期和时间都不重复

这次成功了,结果如下:

日期不重复测试成功

那日期不重复,时间重复呢?

测试数据:日期不重复时间重复

刷新,一切正常:

时间重复也没关系
查阅微软的官方说明,也并没有明确指出LASTDATE这个函数要求引用的日期列不得有重复日期,但是在页面末尾给出的例子中,还是暗示出了这个限制:
=LASTDATE('InternetSales_USD'[SaleDateKey])

这个SaleDateKey我理解就是日期表的主键,主键当然不能重复。
所以,结论是:

1.当要从日期重复的列中获取最新日期,用MAX()函数;
2.当确定日期列中的日期是不重复的,则可以用LASTDATE()函数;
3.为什么有了MAX()函数之后,还要有LASTDATE()这个专门的函数呢?不得而知。

相关文章

  • DAX中LASTDATE()函数引用的日期列不得存在重复日期

    在《Power Pivot Alchemy》Page17,作者提到可以在DAX中用LASTDATE获取最新日期: ...

  • PowerBI DAX函数:UNICHAR

    周末分享:DAX函数卡片 DAX中的日期函数:UNICHAR, 返回数值引用的UNICODE字符,语法如下: 利用...

  • PowerBI DAX函数学习:CALENDARAUTO

    假日分享:DAX函数卡片 DAX中生成一列日期的表函数:CALENDARAUTO,语法如下: 创建日期表时,利用C...

  • PowerBI DAX函数:EDATE

    周末分享:DAX函数卡片 DAX中的日期函数:EDATE,语法如下: 看EDATE这个函数,移动一定月份之后的日期...

  • PowerBI DAX函数:WEEKNUM

    周末分享:DAX函数卡片 DAX中的日期函数:WEEKNUM, 返回日期在该年中的周序号,语法如下: 该函数同WE...

  • Power BI DAX函数学习:CALENDAR

    周末分享:DAX函数卡片。 DAX中建日期表常用的函数:CALENDAR,具体语法和用法如下: 该函数是个表函数,...

  • PowerBI DAX函数:DATE

    周末分享:DAX函数卡片 DAX中的日期函数:DATE,语法如下: 这个函数很简单,却非常实用,很多同学学习的时候...

  • PowerBI DAX函数学习:LASTDATE

    周末分享:DAX函数卡片。 DAX中常用的时间智能函数:LASTDATE,用于返回最后一天,具体语法和用法如下: ...

  • PowerBI DAX函数学习:YEARFRAC

    周末分享:DAX函数卡片 DAX中精确计算两个日期间隔年度的函数:YEARFRAC,语法如下: 这个函数注意与DA...

  • PowerBI DAX函数:WEEKDAY

    周末分享:DAX函数卡片 DAX中的日期函数:WEEKDAY, 返回周几的数字,语法如下: 在进行周分析时,需要知...

网友评论

    本文标题:DAX中LASTDATE()函数引用的日期列不得存在重复日期

    本文链接:https://www.haomeiwen.com/subject/jwrrdttx.html