如何使用linq通过entity.ids找到匹配实体的最大日期

本文关键字:实体 日期 linq 何使用 通过 entity ids | 更新日期: 2023-09-27 18:24:13

如何使用linq来查找使用mvc 4、ef5和linq匹配cat id的最后一个cat状态?

示例目前不起作用b/c max不允许只对int、dec等进行日期时间检查……我必须将其分解为至少7或8个日期时间的每个部分的最大检查,如年、月、天、小时、分钟、秒、毫秒等……但我正在寻找比这更好的方法:

cat.CatStatuses = dbCat.CatStatuses.Where(catstatus => catstatus.id == catstatus.id).Where(catstatus => catstatus.date == (dbCat.CatStatuses.Max(catstatus.date)));

在linq、mvc 4和实体框架中,有没有更好、更有效的方法来做到这一点?我试图使用func语句来更好地执行此操作。

Cat状态可能如下:"躺下"、"站起来"、"咆哮"、"喵"、"抓挠大师"、"攀爬"、"用餐"、"抓老鼠"

Cat状态日期是状态发生的日期和时间。

我的问题是,如何在ef5环境中使用linq以最有效的方式在最大cat状态日期前获得最后一个cat状态?

如何使用linq通过entity.ids找到匹配实体的最大日期

尝试:

dbCat.CatStatuses.OrderBy(x => x.date).Last();
//where the variable catStatusId contains the value of the id you want.
cat.CatStatuses = dbCat.CatStatuses.Where(catstatus => catstatus.id == catStatusId).OrderByDescending(catstatus=>catstatus.Date).FirstOrDefault();

Jonni的建议很好,但是,您应该减少您选择的数据,如下所示:

dbCat.CatStatuses =
    dbCat.CatStatuses.Where(cs => cs.id == catStatusId)
        .OrderByDescending(cs => cs.Date)
        .Select(cs => cs.status)
        .FirstOrDefault();

这或多或少相当于:

select top(1)
    status
from DbCat.dbo.CatStatuses cs
where cs.id == @catStatusId
order by cs.Date desc

或者更像:

select top(1)
    status
    from
    (
        select status, date
        from DbCat.dbo.CatStatuses cs
        where cs.id == @catStatusId
        order by cs.date desc
    ) x

如果你有正确的索引,这是有效的。