我正在玩RavenDb并想知道我是否遗漏了一些明显的东西.
事情是,如果我传递这样的查询:
var name = "test";
posts = RavenSession.Query<Post>()
.Where(x => x.Tags.Any(y => y == name))
.OrderByDescending(x => x.CreatedAt)
.Take(5);
Run Code Online (Sandbox Code Playgroud)
它工作正常,如果我正在编写等效(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);
Run Code Online (Sandbox Code Playgroud)
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));
Run Code Online (Sandbox Code Playgroud)
所以现在只是为什么Raven Db查询构建器的行为不同.
尝试使用Expression代替:
Expression<Func<Post, bool>> selector = x => x.Tags.Any(y => y == name);
Run Code Online (Sandbox Code Playgroud)
并Where(x => selector(x))改为Where(selector).
这Expression是必需的,因为RavenDb可以从中构建表达式树,这允许它将逻辑转换为数据库查询.它无法从a构建表达式树Func<Post, bool>,因此它可能会忽略它,抛出一个exeption或RavenDb指定的创建者.
| 归档时间: |
|
| 查看次数: |
443 次 |
| 最近记录: |