Как получить правильные данные?

У меня есть этот запрос ElasticSearch для ES, версия: 2.2:

{
    "query": {
        "bool": {
            "must": [
                {
                     "term": {
                        "companyId": 3211002
                    }
                },
                {
                    "bool": {
                        "should": [
                            {
                                "term": {
                                    "hrId": 1005031
                                }
                            },
                            {
                                "terms": {
                                    "manager": [
                                        1005031
                                    ]
                                }
                            },
                            {
                                "bool": {
                                    "must": [
                                        {
                                            "exists": {
                                                "field": "manager"
                                            }
                                        },
                                        {
                                            "terms": {
                                                "manager": []
                                            }
                                        }
                                    ]
                                }
                            },
                            {
                                "bool": {
                                    "must_not": {
                                        "exists": {
                                            "field": "manager"
                                        }
                                    }
                                }
                            }
                        ],
                        "minimum_should_match": "1"
                    }
                },
                {
                    "terms": {
                        "status": [
                            "0"
                        ]
                    }
                },
                {
                    "bool": {
                        "should": [
                            {
                                "bool": {
                                    "must_not": {
                                        "exists": {
                                            "field": "approvals"
                                        }
                                    }
                                }
                            },
                            {
                                "nested": {
                                    "query": {
                                        "terms": {
                                            "approvals.approvalStatus": [
                                                1
                                            ]
                                        }
                                    },
                                    "path": "approvals"
                                }
                            }
                        ],
                        "minimum_should_match": "1"
                    }
                }
            ]
        }
    },
    "sort": [
        {
            "createTime": {
                "order": "desc"
            }
        }
    ]
}

Но ES возвращает мне это:

{
    "hits": {
        "total": 2,
        "max_score": null,
        "hits": [
            {
                "_index": "recruitment",
                "_type": "requirement",
                "_id": "501",
                "_score": null,
                "_source": {
                    "id": 501,
                    "companyId": 3211002,
                    "hrId": 1005031,
                    "formId": 501,
                    "requirementId": "Test0004",
                    "positionTitle": "招聘需求004",
                    "positionProperties": 1,
                    "requirementCount": 3,
                    "requirementType": 1,
                    "reportTo": 1004651,
                    "requirementTeam": 188384773,
                    "requirementStatus": 0,
                    "manager": [
                        1005031
                    ],
                    "status": 0,
                    "createTime": 1685350126881,
                    "hasAttachment": false
                },
                "sort": [
                    1685350126881
                ]
            },
            {
                "_index": "recruitment",
                "_type": "requirement",
                "_id": "498",
                "_score": null,
                "_source": {
                    "id": 498,
                    "companyId": 3211002,
                    "hrId": 1004483,
                    "formId": 498,
                    "requirementId": "Test0002",
                    "positionTitle": "审批测试1",
                    "positionProperties": 2,
                    "requirementCount": 2,
                    "requirementStatus": 0,
                    "status": 0,
                    "createTime": 1685346243403,
                    "hasAttachment": false,
                    "approvals": [
                        {
                            "approvalStatus": 1,
                            "nodes": [
                                {
                                    "approvers": [
                                        {
                                            "approverStatus": 3,
                                            "id": 1005031
                                        }
                                    ],
                                    "nodeStatus": 3
                                },
                                {
                                    "approvers": [
                                        {
                                            "approverStatus": 1,
                                            "id": 1004789
                                        },
                                        {
                                            "approverStatus": 1,
                                            "id": 1004483
                                        }
                                    ],
                                    "nodeStatus": 1
                                }
                            ],
                            "createTime": "2023-05-29T15:44:07+08:00",
                            "hrId": 1004483,
                            "id": 597
                        }
                    ]
                },
                "sort": [
                    1685346243403
                ]
            }
        ]
    }
}

Я не понимаю, почему возвращается ID = 498.

Моя цель - отфильтровать id = 498, я не знаю, как это сделать.

Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
В компьютерном программировании биты играют важнейшую роль в представлении и манипулировании данными на двоичном уровне. Побитовые операции...
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Приходилось ли вам сталкиваться с требованиями, в которых вас могли попросить поднять тревогу или выдать ошибку, когда метод Java занимает больше...
Полный курс Java для разработчиков веб-сайтов и приложений
Полный курс Java для разработчиков веб-сайтов и приложений
Получите сертификат Java Web и Application Developer, используя наш курс.
0
0
50
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Вы должны добавить вложенный запрос внутрь must_not, он должен работать:

GET test_hr/_search
{
  "query": {
    "bool": {
      "must": [
        {
          "term": {
            "companyId": 3211002
          }
        },
        {
          "bool": {
            "should": [
              {
                "term": {
                  "hrId": 1005031
                }
              },
              {
                "terms": {
                  "manager": [
                    1005031
                  ]
                }
              },
              {
                "bool": {
                  "must": [
                    {
                      "exists": {
                        "field": "manager"
                      }
                    },
                    {
                      "terms": {
                        "manager": []
                      }
                    }
                  ]
                }
              },
              {
                "bool": {
                  "must_not": {
                    "exists": {
                      "field": "manager"
                    }
                  }
                }
              }
            ],
            "minimum_should_match": "1"
          }
        },
        {
          "terms": {
            "status": [
              "0"
            ]
          }
        },
        {
          "bool": {
            "should": [
              {
                "bool": {
                  "must_not": {
                    "nested": {
                      "path": "approvals",
                      "query": {
                        "exists": {
                          "field": "approvals"
                        }
                      }
                    }
                  }
                }
              }
            ],
            "minimum_should_match": "1"
          }
        }
      ]
    }
  },
  "sort": [
    {
      "createTime": {
        "order": "desc"
      }
    }
  ]
}

тест

PUT test_hr
{
  "mappings": {
    "properties": {
      "approvals":{
        "type": "nested"
      }
    }
  }
}

PUT test_hr/_doc/501
{
  "id": 501,
  "companyId": 3211002,
  "hrId": 1005031,
  "formId": 501,
  "requirementId": "Test0004",
  "positionTitle": "招聘需求004",
  "positionProperties": 1,
  "requirementCount": 3,
  "requirementType": 1,
  "reportTo": 1004651,
  "requirementTeam": 188384773,
  "requirementStatus": 0,
  "manager": [
    1005031
  ],
  "status": 0,
  "createTime": 1685350126881,
  "hasAttachment": false
}

PUT test_hr/_doc/498
{
  "id": 498,
  "companyId": 3211002,
  "hrId": 1004483,
  "formId": 498,
  "requirementId": "Test0002",
  "positionTitle": "审批测试1",
  "positionProperties": 2,
  "requirementCount": 2,
  "requirementStatus": 0,
  "status": 0,
  "createTime": 1685346243403,
  "hasAttachment": false,
  "approvals": [
    {
      "approvalStatus": 1,
      "nodes": [
        {
          "approvers": [
            {
              "approverStatus": 3,
              "id": 1005031
            }
          ],
          "nodeStatus": 3
        },
        {
          "approvers": [
            {
              "approverStatus": 1,
              "id": 1004789
            },
            {
              "approverStatus": 1,
              "id": 1004483
            }
          ],
          "nodeStatus": 1
        }
      ],
      "createTime": "2023-05-29T15:44:07+08:00",
      "hrId": 1004483,
      "id": 597
    }
  ]
}

#not working
GET test_hr/_search
{
  "query": {
    "bool": {
      "must_not": [
        {
          "exists": {
            "field": "approvals"
          }
        }
      ]
    }
  }
}

#working
GET test_hr/_search
{
  "query": {
    "bool": {
      "must_not": [
        {
          "nested": {
            "path": "approvals",
            "query": {
              "exists": {
                "field": "approvals"
              }
            }
          }
        }
      ]
    }
  }
}

спасибо за вашу помощь! Я столкнулся с другой проблемой: как мне использовать rangeQuery для поиска нижнего предела заработной платы ('salaryBottom') и верхнего предела заработной платы ('salaryTop')? как зарплата между 11 и 15

ZhuXJun 05.06.2023 04:59

Пожалуйста, рад слышать, что это сработало. Пожалуйста, задайте другой вопрос и пингуйте меня. Было бы здорово, если бы вы также могли привести примеры, как вы сделали для этого вопроса :)

Musab Dogan 05.06.2023 10:51

Хорошо, вот ссылка на новый вопрос:stackoverflow.com/questions/76405037/elastic-search‌​-rangequery

ZhuXJun 05.06.2023 11:23

Вал ответил на вопрос :)

Musab Dogan 05.06.2023 11:52

В любом случае, благодарю Вас :)

ZhuXJun 05.06.2023 12:00

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

Попытка подключения не удалась, потому что подключенная сторона не ответила должным образом через некоторое время - весенняя безопасность, веб-клиент
Как поймать исключение тайм-аута в Spring WebClient?
Ошибка при попытке получить данные GET/POST в PostgreSQL с использованием Spring Data JPA REST API
Проблема с именем сопоставления параметров JSON с классом DTO в весенней загрузке
Ошибка при создании компонента с именем «entityManagerFactory»?
Унаследованное поле с автоматическим связыванием не инициализируется к моменту выполнения кода конструктора. Почему и как решить эту проблему?
Как сделать шаблон проектирования «строитель» и внедрение зависимостей Spring совместимыми друг с другом?
Устаревшая проблема Spring Security
Как запретить приложению Spring Boot создавать экземпляр источника данных JDBC во время тестов?
Hibernate 6.1.x / Spring Boot: избегайте создания глобальной временной таблицы