[英]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.