首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用linq通过entity.ids查找匹配实体的最大日期

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

Stack Overflow用户
提问于 2013-07-23 02:43:30
回答 3查看 1.3K关注 0票数 2

如何使用linq通过MVC4、ef5和linq查找匹配cat ids的最后一次cat状态?

示例当前不能正常工作b/c max不允许datetime仅支持int、dec等。我将不得不将其分解为至少7或8个最大检查日期时间的每个部分,如年,月,日,小时,分钟,秒,毫秒,等等……但我正在寻找一种比这更好的方法:

代码语言:javascript
复制
cat.CatStatuses = dbCat.CatStatuses.Where(catstatus => catstatus.id == catstatus.id).Where(catstatus => catstatus.date == (dbCat.CatStatuses.Max(catstatus.date)));

在linq、MVC4和entity框架中,有没有更好、更有效的方法来做到这一点?我正在尝试使用func语句来使其更好地工作。

猫的状态可能类似于:“躺下来”、“起来”、“咆哮”、“猫叫”、“抓猫师父”、“爬”、“吃饭”、“抓老鼠”。

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

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

EN

回答 3

Stack Overflow用户

发布于 2013-07-23 02:52:27

尝试:

代码语言:javascript
复制
dbCat.CatStatuses.OrderBy(x => x.date).Last();
票数 4
EN

Stack Overflow用户

发布于 2013-07-23 02:57:02

代码语言:javascript
复制
//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();
票数 1
EN

Stack Overflow用户

发布于 2014-06-23 03:09:08

Jonni的建议很好,但是,您应该像这样减少您选择的数据:

代码语言:javascript
复制
dbCat.CatStatuses =
    dbCat.CatStatuses.Where(cs => cs.id == catStatusId)
        .OrderByDescending(cs => cs.Date)
        .Select(cs => cs.status)
        .FirstOrDefault();

这或多或少相当于:

代码语言:javascript
复制
select top(1)
    status
from DbCat.dbo.CatStatuses cs
where cs.id == @catStatusId
order by cs.Date desc

或者更像这样:

代码语言:javascript
复制
select top(1)
    status
    from
    (
        select status, date
        from DbCat.dbo.CatStatuses cs
        where cs.id == @catStatusId
        order by cs.date desc
    ) x

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

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17795026

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档