我试图构建一个ElasticSearch查询,但没有得到我期望的结果 . 任何帮助将非常感激!
Mapping Details:
我索引了代表志愿者机会的文件 . 每个机会都有以下字段:
-
对手的头衔,
-
摘要,
-
批准状态,和
-
隐私设置 .
此外,每个机会文件都有:
-
一个嵌套的非营利性文件,代表志愿者机会的非营利主机,
-
一个或多个嵌套的原因文档,表示机会所解决的原因,
-
零个或多个嵌套技能文件,代表志愿者所需的技能,以及
-
零个或多个嵌套班次文件,代表志愿者可以注册的时间段 .
目前,每个嵌套的班次文档都包含一个带有开始和结束日期时间字段的嵌套日历框文档,以及可以注册该班次的最大志愿者数量的字段 .
The Query
我试图构建的查询是一个过滤的查询 . 查询字符串从Web上的表单传入 . 然后,我需要以编程方式将至少三个过滤器附加到此查询:
-
条款过滤器仅返回"approved"的机会:"y"
-
条款过滤器仅返回"private"的机会:"n"
-
范围过滤器,仅返回具有至少一个班次的机会,其中calendarBlock结束字段大于当前日期/时间 . (IE:过滤掉所有过去的班次 . )
前两个过滤器工作正常 . 第三个是我被困住的地方 . 我认为问题可能与复杂的嵌套结构有关 . 我尝试了一个嵌套过滤器,但我不确定我是否正确地做了这个 . 此外,日期字段实际上嵌套了两个级别 . 当我尝试查询时,我仍然得到过去轮班的结果 .
在没有安排未来班次的情况下,完成过滤所有机会的正确方法是什么?
1 回答
我的问题与我格式化日期时间的方式有关 .