1

我正在为一个对象创建一个索引,并且希望能够同时进行完整的短语搜索和部分匹配。该类型称为“deponent”,简化的索引创建如下所示:

{
   "deponent": {
      "properties": {         
         "name": {
            "type": "multi_field",
            "fields": {
               "name": {
                  "type": "string"
               },
               "full": {
                  "type": "string",
                  "index": "not_analyzed",
                  "omit_norms": true,
                  "index_options": "docs",
                  "include_in_all": false
               }
            }
         }
      }
   }
}

这样做的目的是对“name”字段中的值进行两次索引:一次是字段中的单个单词没有被分解(name.full),一次是单词被分解(name.name)。

我有一个已被索引的文档,其名称字段设置为“Danny Watson 博士”。我希望在执行术语查询时会发生以下行为(根据文档未分析其查询字符串):

  1. 使用“Danny Watson 博士” 搜索name.full时,返回记录
  2. 使用“Watson”搜索name.full时,不应返回记录
  3. 使用“Danny Watson 博士”搜索name.name时,不应返回记录
  4. 使用 "Watson"搜索name.name时,返回记录

以上四点的查询:

1 - 按预期工作(返回记录)

{
    "query" : {
        "term": {
           "name.full": {
              "value": "Dr. Danny Watson"
           }
        }
    }   
}

2 - 按预期工作(不返回记录)

{
    "query" : {
        "term": {
           "name.full": {
              "value": "Watson"
           }
        }
    }   
}

3 - 按预期工作(不返回记录)

{
    "query" : {
        "term": {
           "name.name": {
              "value": "Dr. Danny Watson"
           }
        }
    }   
}

4 - 不预期工作 - 不返回记录

{
    "query" : {
        "term": {
           "name.name": {
              "value": "Watson"
           }
        }
    }   
}

所以看来我对某事的理解是有缺陷的。我错过了什么?

4

1 回答 1

1

您不需要调用字段“name.name”。具有原始名称的多字段用作默认值,因此您应该只使用“名称”。
此外,确保索引和搜索分析器按顺序排列总是好的(例如,您的索引词和搜索词都更改为小写)。

于 2013-10-21T14:52:32.000 回答