Почему не работает nested запрос с must_not?

Добрый день коллеги!

У меня есть следующий запрос:

{
    "query": {
        "bool": {
            "filter": [
                {
                    "nested": {
                        "path": "customer",
                        "query": {
                            "bool": {
                                "should": [
                                    {
                                        "term": {
                                            "customer.data": "школа"
                                        }
                                    }
                                ]
                            }
                        }
                    }
                },
                {
                    "nested": {
                        "path": "customer",
                        "query": {
                            "bool": {
                                "must_not": {
                                    "terms": {
                                        "customer.id": [
                                            "7648158"
                                        ]
                                    }
                                }
                            }
                        }
                    }
                }
            ]
        }
    }
}

такой запрос не работает корректно (не происходит исключения по полю customer.id), однако, если переписать его следующим образом (вынести nested запрос в must_not, то он отрабатывает):

"bool": {
            "filter": [
                {
                    "nested": {
                        "path": "customer",
                        "query": {
                            "bool": {
                                "should": [
                                    {
                                        "term": {
                                            "customer.data": "школа"
                                        }
                                    }
                                ]
                            }
                        }
                    }
                },
                {
                  "bool": {
                    "must_not":{
                    "nested": {
                        "path": "customer",
                        "query":  {
                                    "terms": {
                                        "customer.id": [
                                            "76481580"
                                        ]
                                    }
                                }
                    }
                }
                  }
                }
            ]
        }

почему так происходит? это ожидаемое поведение?

Я не знаю, что вы пытаетесь добиться и какая у вас структура документа, но эти запросы будут работать по разному, если у вас несколько вложенных документов по пути customer. Первый запрос будет включать документы где хотя-бы один nested customer не имеет customer.id = 76481580. Второй запрос будет исключать все документы в которых хотя-бы один документ имеет customer.id = 76481580. То есть в первом случае, вы фильтруете по всеобщности (ALL) и во втором случае - по существованию (ANY).

This topic was automatically closed 28 days after the last reply. New replies are no longer allowed.