1

Elasticsearch 的文章概述了如何通过一代人的搜索来查找对象:https ://www.elastic.co/guide/en/elasticsearch/guide/current/grandparents.html

GET /company/country/_search
{
  "query": {
    "has_child": {
      "type": "branch",
      "query": {
        "has_child": {
          "type": "employee",
          "query": {
            "match": {
              "hobby": "hiking"
            }
          }
        }
      }
    }
  }
}

如果我还想查询name以“liverpool”开头的分支怎么办?您如何修改此搜索以找到它?我不断收到格式错误,我似乎无法找到有关如何在线嵌套查询的信息。

我已经尝试过了(它不起作用):

GET /company/country/_search
{
  "query": {
    "has_child": {
      "type": "branch",
      "query": {
        "has_child": {
          "type": "employee",
          "query": {
            "match": {
              "hobby": "hiking"
            }
          }
        },
        "match": {
          "name": "london"
        }
      }
    }
  }
}

我收到一个错误,说查询格式不正确。

我试过bool了,但它也不起作用;我不能将 has_child 与 bool 一起使用。

4

1 回答 1

0

我能够使它与bool query一起工作。

如果我正确理解你的问题,这应该做你想要的:

POST /company/country/_search
{
   "query": {
      "has_child": {
         "type": "branch",
         "query": {
            "bool": {
               "must": [
                  {
                     "has_child": {
                        "type": "employee",
                        "query": {
                           "match": {
                              "hobby": "hiking"
                           }
                        }
                     }
                  },
                  {
                     "match": {
                        "name": "liverpool"
                     }
                  }
               ]
            }
         }
      }
   }
}

如果您希望查询是“OR”而不是“AND”,请使用"should"代替"must".

这是我设置的一些代码来解决这个问题:

http://sense.qbox.io/gist/cf4babbbd25a3b7a26f3ea9ce9c1b686e37dbcb9

于 2015-10-30T02:42:12.633 回答