Я пытаюсь выполнить поиск в моей базе данных и использовать термины фильтра верхнего/нижнего регистра, но я заметил, что в то время как query
применять анализаторы, я не могу понять, как применять анализатор нижнего регистра в отфильтрованном поиске, Здесь запрос:
{
"query": {
"filtered": {
"filter": {
"bool": {
"should": [
{
"term": {
"language": "mandarin" // Returns a doc
}
},
{
"term": {
"language": "Italian" // Does NOT return a doc, but will if lowercased
}
}
]
}
}
}
}
}
У меня есть тип languages
, который у меня есть внизу, используя:
"analyzer": {
"lower_keyword": {
"type": "custom",
"tokenizer": "keyword",
"filter": "lowercase"
}
}
и соответствующее отображение:
"mappings": {
"languages": {
"_id": {
"path": "languageID"
},
"properties": {
"languageID": {
"type": "integer"
},
"language": {
"type": "string",
"analyzer": "lower_keyword"
},
"native": {
"type": "string",
"analyzer": "keyword"
},
"meta": {
"type": "nested"
},
"language_suggest": {
"type": "completion"
}
}
}
}