我在ElasticSearch环境中工作,我在本地机器上安装了版本5.4.3的elasticsearch。我试图通过定义一些设置和映射来创建索引。以下是我的设置和映射,
{
"settings":{
"index":{
"analysis":{
"analyzer":{
"index_analyzer":{
"filter":[
"standard",
"lowercase",
"asciifolding"
],
"tokenizer":"standard"
},
"autocomplete":{
"type":"custom",
"tokenizer":"standard",
"filter":[
"lowercase",
"autocomplete_filter"
]
},
"search_analyzer":{
"filter":[
"standard",
"lowercase",
"asciifolding"
],
"tokenizer":"standard"
},
"sortable":{
"filter":"lowercaseFilter",
"tokenizer":"keyword",
"type":"custom"
}
},
"filter":{
"lowercaseFilter":{
"type":"lowercase"
},
"autocomplete_filter":{
"type":"edge_ngram",
"min_gram":1,
"max_gram":20
}
},
"tokenizer":{
"keyword":{
"type":"keyword"
}
}
}
}
}
}
这是我的映射,
{
"geo_data":{
"_all":{
"enabled":true,
"index_analyzer":"index_analyzer",
"search_analyzer":"search_analyzer"
},
"properties":{
"subscriber_level":{
"analyzer":"index_analyzer,search_analyzer,autocomplete_analyzer",
"type":"text"
},
"att_id":{
"analyzer":"index_analyzer,search_analyzer,autocomplete_analyzer",
"type":"text"
},
"id":{
"include_in_all":false,
"type":"text"
},
"name":{
"analyzer":"index_analyzer,search_analyzer,autocomplete_analyzer",
"type":"text"
},
"state_name":{
"analyzer":"index_analyzer,search_analyzer,autocomplete_analyzer",
"type":"text"
}
}
}
}
我想要实现的是,我想将所有自定义分析仪应用于单个字段。但是在分析器的字段上的映射上面给出了以下异常,
{
"error":{
"root_cause":[
{
"type":"mapper_parsing_exception",
"reason":"analyzer [index_analyzer,search_analyzer,autocomplete_analyzer] not found for field [subscriber_level]"
}
],
"type":"mapper_parsing_exception",
"reason":"analyzer [index_analyzer,search_analyzer,autocomplete_analyzer] not found for field [subscriber_level]"
},
"status":400
}
请有人帮助我解决这个问题,并努力解决这个问题。
答案 0 :(得分:3)
您希望使用多个分析器对同一字段进行标记。您可以使用multi-fields并对多个字段中的每种类型应用不同的分析器。
同样遵循此github issue,_all字段的配置将更改为5.4。 如果您的索引已经存在,
PUT some_index/_mappings/type_name
{
"_all": {
"enabled": true,
"type": "text",
"analyzer": "index_analyzer"
},
"properties": {
"subscriber_level": {
"type": "keyword",
"fields": {
"index_analyzed": {
"type": "text",
"analyzer": "index_analyzer"
},
"search_analyzed": {
"type": "text",
"analyzer": "search_analyzer"
},
"autocomplete_analyzed": {
"type": "text",
"analyzer": "autocomplete"
}
}
},
"att_id": {
"type": "keyword",
"fields": {
"index_analyzed": {
"type": "text",
"analyzer": "index_analyzer"
},
"search_analyzed": {
"type": "text",
"analyzer": "search_analyzer"
},
"autocomplete_analyzed": {
"type": "text",
"analyzer": "autocomplete"
}
}
},
"id": {
"include_in_all": false,
"type": "text"
},
"name": {
"type": "keyword",
"fields": {
"index_analyzed": {
"type": "text",
"analyzer": "index_analyzer"
},
"search_analyzed": {
"type": "text",
"analyzer": "search_analyzer"
},
"autocomplete_analyzed": {
"type": "text",
"analyzer": "autocomplete"
}
}
},
"state_name": {
"type": "keyword",
"fields": {
"index_analyzed": {
"type": "text",
"analyzer": "index_analyzer"
},
"search_analyzed": {
"type": "text",
"analyzer": "search_analyzer"
},
"autocomplete_analyzed": {
"type": "text",
"analyzer": "autocomplete"
}
}
}
},
"settings": {
"index": {
"analysis": {
"analyzer": {
"index_analyzer": {
"filter": [
"standard",
"lowercase",
"asciifolding"
],
"tokenizer": "standard"
},
"autocomplete": {
"type": "custom",
"tokenizer": "standard",
"filter": [
"lowercase",
"autocomplete_filter"
]
},
"search_analyzer": {
"filter": [
"standard",
"lowercase",
"asciifolding"
],
"tokenizer": "standard"
},
"sortable": {
"filter": "lowercaseFilter",
"tokenizer": "keyword",
"type": "custom"
}
},
"filter": {
"lowercaseFilter": {
"type": "lowercase"
},
"autocomplete_filter": {
"type": "edge_ngram",
"min_gram": 1,
"max_gram": 20
}
},
"tokenizer": {
"keyword": {
"type": "keyword"
}
}
}
}
}
}
现在您使用任何分析的字段进行查询,如下所示
POST some_index/_search
{
"query": {
"term": {
"state_name.index_analyzed": {
"value": "VALUE"
}
}
}
}
由于