6

私は 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 つの問題です。

4

2 に答える 2

9

Expression代わりに使用してみてください:

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

に変更Where(x => selector(x))Where(selector)ます。

ExpressionRavenDb はそこから式ツリーを構築できるため、anが必要です。これにより、ロジックをデータベース クエリに変換できます。から式ツリーを構築することはできないため、それをFunc<Post, bool>無視するか、例外をスローするか、または RavenDb の作成者が指定したものをスローする可能性があります。

于 2012-06-25T14:18:17.473 に答える
3

あなたの更新への応答として、構文的に同一に見えるFunc<>onIEnumerable<>Expression<Func<>>onの間には大きな動作上の違いがあります。IQueryable<>これは Raven だけではなくIQueryable<>、LINQ to SQL や Entity Framework などのあらゆるソースです。

于 2012-06-25T14:55:09.680 に答える