是否有一种方法可以比较Linq2Sql中的两个DateTime变量,但忽略时间部分。

应用程序将项目存储在数据库中,并添加发布日期。我想保持准确的时间,但仍然能够拉到日期本身。

我想比较12/3/89 12:43:34和12/3/89 11:22:12,并忽略一天中的实际时间,因此这两者都被认为是相同的。

我想我可以在比较之前将一天中的所有时间设置为00:00:00,但我实际上想知道一天中的时间,我也希望能够仅通过日期进行比较。

我发现一些代码有同样的问题,他们分别比较年,月和日。还有更好的办法吗?


当前回答

在连接或where子句中,使用列的Date属性。在幕后,它执行一个CONVERT(DATE, <expression>)操作。这将允许您比较日期而不考虑时间。

其他回答

要进行真正的比较,你可以使用:

dateTime1.Date.CompareTo(dateTime2.Date);

在连接或where子句中,使用列的Date属性。在幕后,它执行一个CONVERT(DATE, <expression>)操作。这将允许您比较日期而不考虑时间。

DateTime dt1=DateTime.ParseExact(date1,"dd-MM-yyyy",null);
DateTime dt2=DateTime.ParseExact(date2,"dd-MM-yyyy",null);

int cmp=dt1.CompareTo(dt2);

   if(cmp>0) {
       // date1 is greater means date1 is comes after date2
   } else if(cmp<0) {
       // date2 is greater means date1 is comes after date1
   } else {
       // date1 is same as date2
   }
DateTime? NextChoiceDate = new DateTime();
DateTIme? NextSwitchDate = new DateTime();
if(NextChoiceDate.Value.Date == NextSwitchDate.Value.Date)
{
Console.WriteLine("Equal");
}

如果您正在使用可为空的DateFields,则可以使用此选项。

为了使用LINQ,我是这样做的。

DateTime date_time_to_compare = DateTime.Now;
//Compare only date parts
context.YourObject.FirstOrDefault(r =>
                EntityFunctions.TruncateTime(r.date) == EntityFunctions.TruncateTime(date_to_compare));

如果您只使用dtOne。日期== dt2。日期它不会与LINQ一起工作(错误:指定类型成员“日期”在LINQ to Entities中不支持)