簡體   English   中英

實體框架和時間跨度計算

[英]Entity Framework and timespan computation

如何使用EF獲取年齡超過21歲的人?

from person in context.Persons
where DateTime.UtcNow - person.Dob > TimeSpan.FromHours(184086)
select new {person, Age = DateTime.UtcNow - person.Dob}

以上失敗。

我該怎么做才能解決此問題? 以上版本在EF的最新版本中受支持嗎? 4.2+

我可以按以下方式訪問DateTime結構的屬性嗎?

from person in context.Persons
where DateTime.UtcNow.Year - person.Dob.Year > 21
select new {person, Age = DateTime.UtcNow.Year - person.Dob.Year}

您可以在linq-to-entites查詢中使用<運算符。 但是您不能使用加法或減法。 幸運的是, SqlFunctions具有計算日期差的函數。 因此,您可以執行以下操作:

var d21 = DateTime.Today.AddYears(-21);
var q = from person in context.Persons
        where person.Dob < d21
        select new
        {
            person,
            Age = SqlFunctions.DateDiff("year", person.Dob, DateTime.Today)
        }

您必須先創建變量d21 ,否則EF會抱怨不知道AddYears

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM