11

我在弹性搜索中存储了以下信息:

{ "timeslot_start_at" : "2013-02-01", "timeslot_end_at" : "2013-02-03" }

鉴于我有另一个日期范围(例如从用户输入给出),我想搜索一个相交的时间范围。与此类似:确定两个日期范围是否重叠其中概述了以下逻辑是我所追求的:

(StartDate1 <= EndDate2) and (StartDate2 <= EndDate1)

但我不确定如何将其放入弹性搜索查询中,我是否会使用范围过滤器并仅设置“to”值,而将 from 留空?或者有没有更有效的方法来做到这一点?

4

1 回答 1

18

更新:现在可以使用在 elasticsearch v5.2 中添加的date_range数据类型。对于早期版本的 elasticsearch,以下解决方案仍然适用。

要测试交集,您应该使用 bool 查询将两个范围查询组合成一个查询:

{
    "bool": {
        "must": [
            {
                "range": {
                    "timeslot_start_at": {
                        "lte": "2013-02-28"
                    }
                }
            },
            {
                "range": {
                    "timeslot_end_at": {
                        "gte": "2013-02-03"
                    }
                }
            }
        ]
    }
}
于 2013-05-28T21:45:09.380 回答