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");

     

  • 相关阅读:
    第二阶段冲刺01
    第十三周进度条
    构建之法阅读笔记5
    水王2
    购买一批书的最低价格
    第十二周进度条
    个人工作总结08
    个人工作总结07
    人机交互设计分析之搜狗输入法
    第八周的学习进度条
  • 原文地址:https://www.cnblogs.com/Ricky81317/p/1665955.html
Copyright © 2011-2022 走看看