我正在玩 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 查询构建器的行为不同。