2012-06-25 60 views
6

我在玩RavenDb並想知道我是否錯過了一些明顯的東西。傳遞ravendb查詢爲Func <T, bool>不起作用

事情是,如果我傳遞這樣的查詢:

var name = "test"; 
    posts = RavenSession.Query<Post>() 
     .Where(x => x.Tags.Any(y => y == name)) 
     .OrderByDescending(x => x.CreatedAt) 
     .Take(5); 

它工作正常,如果我使用Func<T, bool>寫當量(IMO),它不會崩潰,但查詢缺少其中條件:

var name = "test";  
Func<Post, bool> selector = x => x.Tags.Any(y => y == name); 
posts = RavenSession.Query<Post>() 
     .Where(x => selector(x)) 
     .OrderByDescending(x => x.CreatedAt) 
     .Take(5); 

探查輸出它喜歡:

查詢= 開始= 0 的pageSize = 5 聚集=無 排序= -CreatedAt

更新: 它的工作原理,如果我使用的表達,而不是Func鍵,所以我想可能是我所記得的,Func鍵和LINQ不對勁,於是寫了一個簡單的測試:

var range = Enumerable.Range(1, 50); 

Func<int, bool> selector = x => x == 42; 
var filtered = range.Where(x => selector(x)); 

所以現在只有問題,爲什麼Raven Db查詢生成器行爲不同。

回答

9

嘗試使用Expression代替:

Expression<Func<Post, bool>> selector = x => x.Tags.Any(y => y == name); 

,並更改Where(x => selector(x))Where(selector)

Expression是必需的,因爲RavenDb可以從中構建一個表達式樹,它允許它將邏輯轉換爲數據庫查詢。它不能從Func<Post, bool>建立表達式樹,所以它可能會忽略它,拋出一個豁免或RavenDb指定的創建者。

+0

我更新了問題,它適用於表達式。 – Giedrius

+0

@Giedrius我在我的答案中添加了一個簡短的解釋。 – Botz3000

3

至於你更新的響應,有Func<>之間的IEnumerable<>Expression<Func<>>IQueryable<>看起來語法上等同顯著的行爲差異。這不僅僅是Raven,還包括LINQ to SQL或實體框架等任何源代碼。

相關問題