[英]How does one use a custom property in a LINQ-to-Entities query?
我有一個類Post
,它是一個Entity Framework模型。 它包含這樣的屬性:
public bool Showable {
get {
return this.Public && this.PublishedDate > DateTime.now
}
}
我可以在這樣的查詢中使用它:
from p in db.Posts where p.Showable select p;
但是當我有一個使用它的屬性時,就像這樣
public IEnumerable<Post> ShowablePosts {
get {
return from p in db.Posts where p.Showable select p;
}
}
那我不能做:
from p in ShowablePosts where p.Id > 42 select p;
它說:
LINQ to Entities中不支持指定的類型成員“Showable”。 僅支持初始值設定項,實體成員和實體導航屬性。
如果將屬性編寫為可翻譯為SQL的Expression
,則可以執行此操作。
這有點復雜,因為它是解決復雜問題的一般方法。
一般的想法是這樣的:LINQ to Entities(像所有 LINQ提供者一樣)無法在運行時將類似屬性的編譯代碼轉換為SQL。 LINQ to Objects可以執行已編譯的代碼,但無法對其進行轉換 。 但是他們可以翻譯Expression<T>
。 所以你可以寫:
public static Expression<Func<Post, bool>> WhereActive
{
get
{
return p => p.Public && p.PublishedDate > DateTime.Now;
}
}
然后你可以寫:
public IEnumerable<Post> ShowablePosts
{
get
{
return db.Posts.Where(WhereActive);
}
}
......和LINQ to Entities可以翻譯它。 帖子I鏈接中的代碼概括了這個想法。
遺憾的是,實體框架根本不支持計算屬性(也就是說,返回計算值而不是對支持字段的引用的屬性),但可能在將來的日期支持它。
我認為最簡單的方法是使用本答案中提到的DelegateDecompiler.EntityFramework
包的Computed
屬性。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.