Как найти один из многих запросов?
Допустим, у меня есть язык запросов, который преобразует запросы на "естественном" языке в запросы эластичного поиска.
Предположим, у нас есть следующий запрос:
(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"
}
}
}
]
}
}
}
Надеюсь, это поможет.