NGram Tokenizer 中 max_gram 和 min_gram 的区别

Chr*_*n A 2 c# elasticsearch nest

我目前正在尝试在 .NET 项目中配置一个 elasticsearch 索引(我是 ES 的新手)。

我们正在使用 NEST 7.3.0

client.Indices.Create(lineItemIndex,
                c => c
                    .Settings(s => s
                    .Analysis(a => a
                        .Analyzers(aa => aa
                            .Custom("mynGram_analyzer",ca => ca
                            .Filters(new List<string> {"lowercase"})
                            .Tokenizer("mynGram")))
                        .TokenFilters(tf => tf
                            .NGram("mynGram", td => td
                                .MaxGram(15).MinGram(4)))))
                    .Map<ElasticSearchLineItem>(m => m
                        .Properties(ps => ps
                            .Text(ss => ss
                            .Name(na => na.LineItemName)
                            .Analyzer("mynGram")))
                        .Properties(ps => ps
                            .Keyword(kw => kw
                                .Name(na => na.LineItemId)))
                        .Properties(ps => ps
                            .Text(ss => ss
                            .Name(na => na.LineItemNumber)
                            .Analyzer("mynGram")))));
Run Code Online (Sandbox Code Playgroud)

我收到以下错误:

类型:非法参数异常原因:“NGram Tokenizer 中 max_gram 和 min_gram 之间的差异必须小于或等于:1但为 [11]。可以通过更改 [index.max_ngram_diff] 索引级别设置来设置此限制。”

我明白问题是什么。但我不知道在哪里设置这个 max_ngram_diff 设置。我正在尝试查看文档

但是他们使用 3 作为最小值和最大值。

我还发现了一个示例,其中他们在 JSON 中有设置,可以发送到 ES,但我无法在 c# 代码中复制它。我希望有一个人可以帮助我。

Rob*_*Rob 7

您可以通过以下方式更改此设置

var createIndexResponse = await client.Indices.CreateAsync("index_name",
    c => c.Settings(s => s.Setting(UpdatableIndexSettings.MaxNGramDiff, 11)));
Run Code Online (Sandbox Code Playgroud)

希望有帮助。