Как найти один из многих запросов?

Допустим, у меня есть язык запросов, который преобразует запросы на "естественном" языке в запросы эластичного поиска.

Предположим, у нас есть следующий запрос:

(type == "my-type" || device_id == "some-device-id") && id == "123456789"

Как я могу добиться этого в эластичном поиске?

Я пробовал:

{
    "bool": {
        "filter": {
            "term": {
                "id": "123456789"
            }
        },
        "should": [
            {
                "term": {
                    "type": "my-type"
                }
            },
            {
                "term": {
                    "device_id": "some-device-id"
                }
            }
        ]
    }
}

но я не этого хочу.

Что я делаю неправильно?

Отображение:

{
    "mappings": {
        "_doc": {
            "properties": {
                "accepted_at":  {
                    "type": "date",
                    "format": "strict_date_optional_time||date_time||epoch_millis"
                },
                "created_at":   {
                    "type": "date",
                    "format": "strict_date_optional_time||date_time||epoch_millis"
                },
                "device_id":    {"type": "keyword"},
                "id":       {"type": "keyword"},
                "location": {"type": "geo_point"},
                "message_id":   {"type": "keyword"},
                "type":     {"type": "keyword"}
            }
        }
    }
}

1 ответ

Решение

В elasticsearch вы можете думать о && как must а также ||как и должно быть в запросе bool, поэтому вы можете перевести этот запрос

(type == "my-type" || device_id == "some-device-id") && id == "123456789"

как

must(should(type == "my-type"),(device_id == "some-device-id"), id == "123456789")

который дает нам этот запрос, когда мы хотим преобразовать его в elasticsearch DSL

{
  "query": {
    "bool": {
      "must": [
        {
          "bool": {
            "should": [
              {
                "term": {
                  "type": {
                    "value": "my-type"
                  }
                }
              },
              {
                "term": {
                  "device_id": {
                    "value": "some-device-id"
                  }
                }
              }
            ]
          }
        },
        {
          "term": {
            "id": {
              "value": "123456789"
            }
          }
        }
      ]
    }
  }
}

Надеюсь, это поможет.

Другие вопросы по тегам