最近一直都觉Entity Framework挺好用的,不过今天碰到一个无奈的问题,我需要在查询中取出距今2周内、一个月内的数据。这本应该是很简单的也是很常见的操作,在Sql Server中DateDiff函数以及.NET中的TimeSpan结构就是做这个事情的,然而,郁闷的是,在EF 1.0中,Linq to Entity竟然不支持这种直接的操作,只支持从一个DateTime结构中利用Year、Month等方法获取年的值、月的值等等这种单值。咋办呢?只能剑走偏锋,对于我的这次操作,需要比较两个日期差多少天,因此,就把参与比较的两个日期都转换为整数,把日期比较转换为整数比较。转换的公式是:
(年-2000)× 384 + 月× 32 + 日
至于为何是384和32,我不得而知啦,如果哪天找到了原因,我会把原因补充到这里的。
另外,如果可以用Entity SQL的话,倒是可以使用Sql Server的DateDiff函数,代码写起来类似这样:
entities.ImportLogs.Where("SqlServer.DATEDIFF('DAY', it.UploadedDate, SqlServer.GETDATE()) = 14");