私は RavenDb で遊んでいて、明らかな何かが欠けているのではないかと思っています。
問題は、次のようなクエリを渡す場合です。
var name = "test";
posts = RavenSession.Query<Post>()
.Where(x => x.Tags.Any(y => y == name))
.OrderByDescending(x => x.CreatedAt)
.Take(5);
を使用して同等の(IMO)を書いている場合、問題Func<T, bool>
なく動作しますが、クラッシュしませんが、クエリが欠落している条件:
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);
Profiler は次のように出力します。
query= start=0 pageSize=5 集約=なし sort=-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 クエリ ビルダーが異なる動作をする理由はただ 1 つの問題です。