如何在LINQ-to-Entities查詢中使用自定義屬性?

.net c# entity-framework linq-to-entities

我有一個類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鏈接中的代碼概括了這個想法。



Related

許可下: CC-BY-SA with attribution
不隸屬於 Stack Overflow
這個KB合法嗎? 是的,了解原因
許可下: CC-BY-SA with attribution
不隸屬於 Stack Overflow
這個KB合法嗎? 是的,了解原因