C#:获取日期范围内的数据库记录

本文关键字:数据库 记录 范围内 取日期 获取 | 更新日期: 2023-09-27 18:32:54

我昨天问了一个问题,我必须在给定日期范围内返回数据库记录。在昨天的问题中,我已经说过,在数据库表中,日期是"nvarchar"类型,在联系数据库管理员后。

类型

现已更改为类型"日期时间"

因此,我正在寻找一个 Linq 表达式来返回给定日期范围内的数据库记录。上一期问题链接:返回日期范围内的数据库结果

法典:

public ActionResult timePeriod(string time)
{
    //Start: month, day, year End: month, day, year --> Numeric values
    string[] times = time.Split(',');                             
    string start = times[0] + " " + times[1] + " " + times[2];
    string end = times[3] + " " + times[4] + " " + times[5];
    var sDate = DateTime.Parse(start);
    var eDate = DateTime.Parse(end);
    //viewModel.Tasks = db.Tasks.   //Linq expression to return values withing range.
    viewModel.EngineerSkills = db.EngineerSkills.ToList();
    viewModel.Categories = db.TaskCategories.ToList();
    gatherInfo(viewModel);
    gatherXML();
    timeRestrictions(viewModel);
    gatherMapPositions(viewModel);
    return View("Index", viewModel);
}

C#:获取日期范围内的数据库记录

//previous code
.....
var viewModelDates = viewModel.Where(p=>p.StartTime >=sDate && p.EndTime<=eDate);
return View("Index", viewModelDates.ToList());

您应该检查StartTime>=sDate and p.EndTime<=endTime的位置。这应该会返回正确的值。我希望你有有效的sDateeDate.

我现在不知道,如果我理解你的问题或否,试试这段代码

var query = (from a in announcements
         where (a.Begins <= RightNow) && (a.Expires >= RightNow)
         select a).ToList();

请尝试以下操作:

viewModel.Tasks = db.Tasks.Where(s => DbFunctions.TruncateTime(s.StartTime) == DbFunctions.TruncateTime(sDate)).ToList();