Elasticsearch query_string 嵌套查询

Elasticsearch query_string nested query

我正在尝试使用 query_string 编写一个查询来检索嵌套对象查询的数据。

我想做的一个查询示例是:

{
  "query": {
    "query_string": {
      "query": "a.id:2"
    }
  }
}

其中"a"是一个嵌套对象,"id"是"a"的一个字段。

我知道我可以使用嵌套查询成功执行此任务,编写如下查询:

{
  "nested": {
    "path": "a"
    "query_string": {
      "query": "a.id:2"
    }
  }
}

但是,我想避免它。我不想自己弄清楚用户正在搜索嵌套字段并修改查询。 我尝试使用 "fields" 参数,但它似乎不适用于嵌套对象。

是否可以直接使用 "query_string" 查询来编写此查询? 可以获得什么语义? (例如,如果我写 "a.id:2 AND a.b:10" 我匹配同一对象或不同对象中的两个字段?)

我做了更多研究,发现这可以通过在映射中将 include_in_parent 设置设置为 true 来实现。

现在您应该可以进行类似

的查询
{
  "query": {
    "query_string": {
      "query": "fields.fieldvalue:sometext"
    }
  }
}

例如:-

"mappings": {
         "documentmetadatavalue": {
            "properties": {
              "id": {
                  "type": "string"
               },
               "fields": {
                 "type": "nested",
                 "include_in_parent": true, 
                 "properties": {
                   "fieldId": {"type": "string"},
                   "fieldvalue": {"type": "string"}
                 }
               }
           }
        }
     }

如果有帮助请告诉我。