Elasticsearch父子映射:在两者中搜索并突出显示

时间:2015-12-15 15:44:26

标签: elasticsearch

我有以下elasticsearch 1.6.2索引映射:父和子文档。一个项目可以有多个文档。文档嵌套,因为它们包含base64数据(mapper-attachments-plugin),无法使用项目进行更新。

"mappings" : {
  "document" : {
    "_parent" : {
      "type" : "item"
    }, 
    "_routing" : {
      "required" : true
    },
    "properties" : {
      "extension" : {
        "type" : "string",
        "term_vector" : "with_positions_offsets",     
        "include_in_all" : true
      }, ...
    },
 }
 "item" : { 
    "properties" : {
      "prop1" : {
        "type" : "string",
        "include_in_all" : true
      }, ...
   }
}

我想搜索两个索引,但始终返回。如果文档中存在匹配项,请返回相应的项目。如果项目中存在匹配项,请返回该项目。如果两者都为真,则返回该项目。

是否可以合并 has_child has_parent 搜索?

此搜索仅搜索文档并返回项目:

{
 "query": {
  "has_child": {
    "type": "document",
    "query": {
      "query_string":{"query":"her*}
  },
     "inner_hits" : {
      "highlight" : {
             "fields" : {
                 "*" : {}              
             }
           }
       }
}

示例

GET index/item/174
{
  "_type" : "item",
  "_id" : "174",
  "_source":{"prop1":"Perjeta construction"}
}

GET index/document/116
{
  "_type" : "document",
  "_id" : "116", 
  "_source":{"extension":"pdf","item": {"id":174},"fileName":"construction plan"}
} 

__POSSIBLE SEARCH RESULT searching for "constr*"__

{
"hits": {
  "total": 1,
  "hits": [
     {
        "_type": "item",
        "_id": "174",
        "_source": {
           "prop1": "Perjeta construction"
        },
        "highlight": {
           "prop1": [
              "Perjeta <em>construction<\/em>"
           ]
        },
        "inner_hits": {
           "document": {
              "hits": {
                 "hits": [
                    {
                       "_type": "document",
                       "_id": "116",
                       "_source": {
                          "extension": "pdf",
                          "item": {
                             "id": 174
                          },                              
                          "fileName": "construction plan"
                       },
                       "highlight": {
                          "fileName": [
                             "<em>construction<\/em> plan"
                          ]
                       }
                    }
                 ]
              }
           }
        }
     }
  ]
}
}

1 个答案:

答案 0 :(得分:0)

我可以回答我的问题“是否可以将has_child和has_parent与 no 结合使用。

您应该只在一个索引上使用一个。