Go 有没有将地理位置搜索查询与距离筛选/排序相结合的示例?

Go 有没有将地理位置搜索查询与距离筛选/排序相结合的示例?,go,sdk,couchbase,gocb,Go,Sdk,Couchbase,Gocb,我正在使用gocb根据地理位置查询文档。到目前为止,NewGeoDistanceQuery与索引配合良好。现在我需要根据地理位置距离对结果进行排序。根据中的文档,它说我需要在查询中传递sort参数!但是NewGeoDistanceQuery没有这个功能。因此,搜索sdk并找到了NewSearchSortGeoDistance,这正是我想要的,但我对如何组合它们感到困惑 location := cbft.NewGeoDistanceQuery(in.Lat, in.Lon, fmt.Spr

我正在使用gocb根据地理位置查询文档。到目前为止,
NewGeoDistanceQuery
与索引配合良好。现在我需要根据地理位置距离对结果进行排序。根据中的文档,它说我需要在查询中传递sort参数!但是
NewGeoDistanceQuery
没有这个功能。因此,搜索sdk并找到了
NewSearchSortGeoDistance
,这正是我想要的,但我对如何组合它们感到困惑

    location := cbft.NewGeoDistanceQuery(in.Lat, in.Lon, fmt.Sprintf("%skm", in.Distance))
    sort := cbft.NewSearchSortGeoDistance("address", in.Lat, in.Lon).Unit("km")
    conjunctionQuery = cbft.NewConjunctionQuery(location, sort)
我尝试了上面的解决方案,但出现了这个错误

{"error":"rest_index: Query, indexName: restaurant-geo-search, err: bleve: QueryBleve parsing searchRequest, err: unknown query type","request":{"ctl":{"timeout":75000},"query":{"conjuncts":[{"distance":"2km","location":[90.404272,23.793993]},{"by":"geo_distance","field":"address","location":[90.404272,23.793993],"unit":"km"}]},"size":100},"status":"fail"}
我还尝试单独使用
NewSearchSortGeoDistance
,但错误相同。这方面有什么帮助吗?

我已经回答了,只是想把所有的信息也放在这里:

我认为这里的问题是,您试图将排序顺序用作查询,而不是作为排序标准。我认为您需要的可能是
gocb.NewSearchQuery(indexName,location).Sort(Sort)
。这将获取排序标准,并将其放入
sort
字段下的JSON请求中,您可以在我们的文档中看到这一点