0

在过去的几天里,我一直带着这个在房子周围尝试各种顺序的东西,但不知道为什么它不起作用。

我正在尝试使用与“标准”分析器相同但在存储记录时保留大写字符的分析器在 Elasticsearch 中创建索引。

我创建我的分析器和索引如下:

PUT /upper
{
"settings": {
    "index" : {
        "analysis" : {
             "analyzer": {
                    "rebuilt_standard": {
                      "tokenizer": "standard",
                      "filter": [
                        "standard"   
                      ]
                }
            }
        }
    }
},
"mappings": {
    "doc": {
        "properties": {
          "title": { 
            "type": "text",
            "analyzer": "rebuilt_standard"
          }
        }
    }
}

}

然后像这样添加两条记录进行测试...

POST /upper/doc
{
"text" : "TEST"
}

添加第二条记录...

POST /upper/doc
{
"text" : "test"
}

使用 /upper/_settings 给出以下结果:

{
  "upper": {
"settings": {
  "index": {
    "number_of_shards": "5",
    "provided_name": "upper",
    "creation_date": "1537788581060",
    "analysis": {
      "analyzer": {
        "rebuilt_standard": {
          "filter": [
            "standard"
          ],
          "tokenizer": "standard"
        }
      }
    },
    "number_of_replicas": "1",
    "uuid": "s4oDgdsFTxOwsdRuPAWEkg",
    "version": {
      "created": "6030299"
    }
  }
}
  }
}

但是当我使用以下查询进行搜索时,我仍然得到两个匹配项!大写和小写都必须意味着在我存储记录时未应用分析器。

像这样搜索...

GET /upper/_search
{
  "query": {
    "term": {
      "text": {
        "value": "test"
      }
  }
}
}

提前致谢!

4

1 回答 1

2

首先,您将分析器设置在title字段上而不是text字段上(因为您的搜索是在 text 属性上,并且因为您正在索引只有text属性的文档)

"properties": {
    "title": { 
        "type": "text",
        "analyzer": "rebuilt_standard"
    }
}

尝试

"properties": {
    "text": { 
        "type": "text",
        "analyzer": "rebuilt_standard"
    }
}

并随时通知我们;)

于 2018-09-24T12:51:48.897 回答