我在玩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查詢生成器行爲不同。
我更新了問題,它適用於表達式。 – Giedrius
@Giedrius我在我的答案中添加了一個簡短的解釋。 – Botz3000