在过去的几天里,我一直带着这个在房子周围尝试各种顺序的东西,但不知道为什么它不起作用。
我正在尝试使用与“标准”分析器相同但在存储记录时保留大写字符的分析器在 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"
}
}
}
}
提前致谢!