Elasticsearch日期查询。出生在某个月的人

时间:2015-09-17 21:43:30

标签: elasticsearch elasticsearch-mapping elasticsearch-dsl elasticsearch-query

我有一个包含以下映射的字段:

birthdate: { type: :date, format: :dateOptionalTime }
  1. 我需要找到5月份出生的所有人(包括所有年份)
  2. 另一个疑问是找到所有出生于8月25日' (包括所有年份)
  3. 对此有什么疑问?

4 个答案:

答案 0 :(得分:3)

您可以使用script filter

来实现此目的

任何一年五月出生的所有人:

{
  "query": {
    "filtered": {
      "filter": {
        "script": {
          "script": "doc.birthdate.date.monthOfYear == 5"
        }
      }
    }
  }
}

所有出生于8月25日(任何一年)的人

{
  "query": {
    "filtered": {
      "filter": {
        "script": {
          "script": "doc.birthdate.date.monthOfYear == 8 && doc.birthdate.date.dayOfMonth == 25"
        }
      }
    }
  }
}

答案 1 :(得分:0)

GET index_name/doc_type/_search
{
    "query": {
        "bool" : {
            "filter" : {
                "script" : {
                    "script" : {
                        "source": "doc.field_name.date.getMonthOfYear() == month_number",
                        "lang": "painless"
                     }
                }
            }
        }
    }
}

答案 2 :(得分:0)

就档案而言,ES 7带来了一些制动变化https://www.elastic.co/guide/en/elasticsearch//reference/current/breaking-changes-7.0.html#_getdate_and_getdates_removed

现在是:

POST /people/_search?size=50
{
  "query": {
    "bool" : {
      "filter" : {
       "script" : {
          "script" : {
            "source": "doc['jour'].value.getMonthValue() == 5",
            "lang": "painless"
          }
        }
      }
    }
  }
}

答案 3 :(得分:-2)

第一个问题:

POST /test_index/_search
{
   "query": {
      "filtered": {
         "filter": {
            "range": {
               "birthdate": {
                  "gte": "2015-05-01",
                  "lt": "2015-06-01"
               }
            }
         }
      }
   }
}

第二个问题:

POST /test_index/_search
{
   "query": {
      "filtered": {
         "filter": {
            "range": {
               "birthdate": {
                  "gte": "2015-08-25",
                  "lte": "2015-08-25"
               }
            }
         }
      }
   }
}

以下是我用来测试它的代码:

http://sense.qbox.io/gist/36c800cabbe4143ecf72144d02e58e267c1e761a