我的目标是搜索一个单词而不管添加的分析器。
我将匹配查询与关键字分析器一起使用,但我认为它适用于添加到该属性的默认分析器。
在弹性搜索中,我的作者文档结构就像
"_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"
}
}
} }
但是当我搜索时,上述文件是匹配的。 我期待的是具有确切价值的组织&#39; le &#39;
为什么匹配?有什么想法实现我的目标吗?
答案 0 :(得分:2)
通过在查询中指定分析器,您指示Elasticsearch如何分析您发送的查询。
例如:
GET /author/_search {
"query": {
"match": {
"Organization": {
"query": "le",
"analyzer": "keyword"
}
}
} }
告诉Elasticsearch在keyword
字符串上使用le
分析器。它不会影响已在您的存储数据上创建的索引字词(let123
)
更改分析存储数据的方式的唯一方法是更新映射并重新索引数据。
不可能在同一个字段中使用多个分析器,但数据可以轻松存储在多个字段中(每个字段都有一个分析器)。
例如:
{
"tweet" : {
"properties" : {
"name" : {
"type" : "string",
"index" : "analyzed",
"fields" : {
"raw" : {"type" : "string", "index" : "not_analyzed"}
}
}
}
}
}
名称数据会自动存储在两个位置 - 字段name
(分析它)和name.raw
(不进行分析)。请参阅Multi Fields。
答案 1 :(得分:0)
GET /author/_search
{
"query": {
"term": "le"
}
}