弹性搜索:与分析器匹配查询不起作用

时间:2015-09-14 13:07:37

标签: c# elasticsearch nest

  

我的目标是搜索一个单词而不管添加的分析器。

我将匹配查询与关键字分析器一起使用,但我认为它适用于添加到该属性的默认分析器。

在弹性搜索中,我的作者文档结构就像

"_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;

为什么匹配?有什么想法实现我的目标吗?

2 个答案:

答案 0 :(得分:2)

通过在查询中指定分析器,您指示Elasticsearch如何分析您发送的查询。

例如:

GET /author/_search {
    "query": {
        "match": {
           "Organization": {
               "query": "le",
               "analyzer": "keyword"
           }
        }
    } }

告诉Elasticsearch在keyword字符串上使用le分析器。它不会影响已在您的存储数据上创建的索引字词(let123

更改分析存储数据的方式的唯一方法是更新映射并重新索引数据。

Multifields

不可能在同一个字段中使用多个分析器,但数据可以轻松存储在多个字段中(每个字段都有一个分析器)。

例如:

{
  "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"
    }
}