将 ravendb 查询传递为 Func<T、bool> 不起作用



我正在玩RavenDb,想知道我是否错过了一些明显的东西。

问题是,如果我像这样传递查询:

  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 页面大小=5 聚合 = 无 排序=-创建于

更新:如果我使用表达式而不是 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 查询生成器的行为不同。

尝试改用Expression

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

并将Where(x => selector(x))更改为Where(selector).

Expression是必需的,因为 RavenDb 可以从中构建表达式树,从而允许它将逻辑转换为数据库查询。 它不能从Func<Post, bool>构建表达式树,所以它可能会忽略它,抛出一个 exption 或任何 RavenDb 的创建者指定的内容。

作为对更新的响应,IEnumerable<>上的Func<>IQueryable<>上的Expression<Func<>>之间存在显著的行为差异,这些行为看起来在语法上是相同的。这不仅仅是 Raven,而是任何IQueryable<>源,如 LINQ to SQL 或 Entity Framework。

最新更新