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>,它不会崩溃,但查询缺少 where 条件:

 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 aggregation=None 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 查询构建器的行为不同。

4

2 回答 2

9

尝试Expression改用:

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

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

AnExpression是必需的,因为 RavenDb 可以从中构建表达式树,这允许它将逻辑转换为数据库查询。它无法从 a 构建表达式树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 回答