试图从数据库中获取本周内的所有日期
我有 email1DueDate、email2DueDate、email3DueDate
我想看看它们是否会在本周内发送
首先,您应该计算一周开始和一周结束的两个 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)
);
如果这不是您所需要的,那么您需要澄清您的要求
LINQ
listOfDates.Where(x => x.email1DueDate > beginOfWeekDate && x.email1DueDate < endOfWeekDate).ToList();
当然,您仍然需要弄清楚开始和结束日期