Elasticsearch 2.1 - 弃用的搜索类型

Elasticsearch 2.1 - Deprecated search types

根据此 linkscancount 均已弃用。

我正在尝试更改我的查询以反映这一点。所以 count 更改很简单,只需删除搜索类型并在请求中添加 size=0,但是,我并不是 100% 接受 scan 更改。

目前我有这个查询:

var result = ElasticClient.Search<Product>(s => s
    .From(0)
    .Size(10)
    .SearchType(SearchType.Scan)
    .Scroll("4s")
    .Query
        (qu =>
            qu.Filtered
                (fil =>
                    fil.Filter
                        (f =>
                            f.Bool(b => b.Must(m => m.Term("filedName", "abc")))))));

我的理解是否正确,我需要更改的只是删除 searchtype 并添加 sort?即:

var result = ElasticClient.Search<Product>(s => s
    .From(0)
    .Size(10)
    .Scroll("4s")
    .Sort(x => x.OnField("_doc"))
    .Query
        (qu =>
            qu.Filtered
                (fil =>
                    fil.Filter
                        (f => f.Bool(b => b.Must(m => m.Term("filedName", "abc")))))));

我看到了枚举 SortSpecialField here,但我不确定如何在 sort 参数中实际使用它。

您的理解是正确的,即按 _doc 排序的更改(如您在问题中记录的那样)将取代已弃用的 Scan 搜索类型。 SortSpecialField 枚举只是按 _doc 排序的语法糖。如果您更喜欢使用它,在 NEST 2.0 [仅] 中,您可以这样做:

ElasticClient.Search<Product>(s => s
.From(0)
.Size(10)
.Scroll("4s")
.Sort(x => x.Ascending(SortSpecialField.DocumentIndexOrder))
    ...