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

     

  • 相关阅读:
    Git 的使用
    state介绍
    salt之pillar组件
    salt之grains组件
    python之commands模块
    install命令
    salt常用模块及API
    locate包的安装
    集中化管理平台Saltstack安装配置
    系统批量运维管理器pexpect的使用
  • 原文地址:https://www.cnblogs.com/Ricky81317/p/1665955.html
Copyright © 2011-2022 走看看