0

试图从数据库中获取本周内的所有日期

我有 email1DueDate、email2DueDate、email3DueDate

我想看看它们是否会在本周内发送

4

2 回答 2

7

首先,您应该计算一周开始和一周结束的两个 DateTime 值,您可以这样做(假设星期一是第一天):

DateTime startOfWeek = DateTime.Today;
int delta = DayOfWeek.Monday - startOfWeek.DayOfWeek;
startOfWeek = startOfWeek.AddDays(delta);

DateTime endOfWeek = startOfWeek.AddDays(7);

接下来,您可以在 LINQ 查询中使用它来获得所需的结果,我假设您希望结果是您的任何截止日期都在一周内的行:

var results = DB.Table.Where(x =>
    (x.email1DueDate >= startOfWeek && x.email1DueDate < endOfWeek) ||
    (x.email2DueDate >= startOfWeek && x.email2DueDate < endOfWeek) ||
    (x.email3DueDate >= startOfWeek && x.email3DueDate < endOfWeek)
    );

如果这不是您所需要的,那么您需要澄清您的要求

于 2012-05-15T09:59:18.467 回答
1

LINQ

listOfDates.Where(x => x.email1DueDate > beginOfWeekDate && x.email1DueDate < endOfWeekDate).ToList();

当然,您仍然需要弄清楚开始和结束日期

于 2012-05-15T09:59:39.767 回答