我的目标是搜索单词,而不考虑添加到其中的分析器。
我将 匹配 查询与 关键字分析器一起使用, 但我认为它可以与添加到该属性的默认分析器一起使用。
在elasticsearch中,我的作者文档结构像
"_source": { "Id": 3, "Organization": "let123" }
索引映射:
createIndexDescriptor.NumberOfReplicas(1) .NumberOfShards(1) .Settings( settings => settings .Add("analysis.filter.autocomplete_filter_ngram.type", "edge_ngram") .Add("analysis.filter.autocomplete_filter_ngram.min_gram", "2") .Add("analysis.filter.autocomplete_filter_ngram.max_gram", "7") .Add("analysis.analyzer.title_analyzer.type", "custom") .Add("analysis.analyzer.title_analyzer.char_filter.0", "html_strip") .Add("analysis.analyzer.title_analyzer.tokenizer", "standard") .Add("analysis.analyzer.title_analyzer.filter.0", "lowercase") .Add("analysis.analyzer.title_analyzer.filter.1", "asciifolding") .Add("analysis.analyzer.title_analyzer.filter.2", "autocomplete_filter_ngram")) .AddMapping<Author>( m => m.MapFromAttributes() .AllField(f => f.Enabled(true)) .Properties( props => props.MultiField( mf => mf.Name(t => t.Organization) .Fields(fs => fs.String(s => s.Name(t => t.Organization).Analyzer("title_analyzer")) ))));
在这里,我注意到我的标题分析器过滤器之一是 ngram
但是我在匹配查询中使用了 关键字分析器 ,以避免搜索过程中自动完成。
GET /author/_search { "query": { "match": { "Organization": { "query": "le", "analyzer": "keyword" } } } }
但是当我搜索时,上面的文件是匹配的。我期望的是组织具有“ le ”的确切价值
为什么这样匹配?有什么想法可以实现我的目标吗?
通过在查询中指定分析器,您可以指示Elasticsearch如何分析已发送的查询。
例如:
告诉Elasticsearch对字符串使用keyword分析器le。它不会影响已在您的存储数据(let123)上创建的索引词
keyword
le
let123
更改存储数据分析方式的唯一方法是更新映射并为数据重新编制索引。
在同一个字段上不可能有多个分析器,但是数据可以轻松地存储在多个字段中(每个字段都有一个分析器)。
{ "tweet" : { "properties" : { "name" : { "type" : "string", "index" : "analyzed", "fields" : { "raw" : {"type" : "string", "index" : "not_analyzed"} } } } } }
名称数据自动存储在两个位置- 字段name(在其中进行分析)和name.raw(不进行分析)中。请参阅多字段。
name
name.raw