如何在NEST中使用ElasticSearch MinHash插件

时间:2015-03-16 07:54:59

标签: nest elasticsearch

我想在NEST Elasticsearch.net中使用MinHash弹性搜索插件。 如何在nest中使用minhash插件?

1 个答案:

答案 0 :(得分:0)

使用以下映射创建索引:

elasticClient.CreateIndex(descriptor => descriptor
    .Index("my_index")
    .Analysis(
        analysis => analysis.Analyzers(bases => bases.Add("minhash_analyzer", new CustomAnalyzer
        {
            Tokenizer = "standard",
            Filter = new[] {"minhash"}
        })))
    .AddMapping<IndexElement>(
        mappingDescriptor =>
            mappingDescriptor
                .Properties(p => p
                    .String(s => s.Name(element => element.Message).CopyTo("minhashvalue"))
                    .Custom(new MiniHashMapping()))));

class MiniHashMapping : BinaryMapping
{
    [JsonProperty("minhash_analyzer")]
    public string Analyzer { get { return "minhash_analyzer"; } }

    public MiniHashMapping()
    {
        Type = "minhash";
        Name = "minhashvalue";
    }
}

class IndexElement
{
    public string Message { get; set; }
}

索引示例文档:

elasticClient.Index(new IndexElement
{
    Message = "Fess is Java based full text search server provided as OSS product."
}, descriptor => descriptor.Index("my_index"));

告诉elasticsearch在回复中包含字段:

var searchResponse = elasticClient.Search<IndexElement>(s => s.Query(q => q.MatchAll()).Fields("*"));

您可以从searchResponse.Hits[..].FieldssearchResponse.FieldSelections获取哈希值。

希望这有帮助。