zoukankan      html  css  js  c++  java
  • Entity Framework 1.0中的日期比较

    最近一直都觉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");

     

  • 相关阅读:
    【CF580D】Kefa and Dishes
    【poj3311】Hie with the Pie
    校外实习-7.7
    校外实习-7.6
    校外实习-7.5
    校外实习-7.4
    作业九-课程总结(补充)
    作业九-课程总结
    作业四——结对编程四则运算
    作业三
  • 原文地址:https://www.cnblogs.com/Ricky81317/p/1665955.html
Copyright © 2011-2022 走看看