从最近到最远排序 Firestore GeoHash 查询?

Ordering Firestore GeoHash query from closest to furthest?

目前,我正在使用部分 GeoFirebase 库和 Firestore 来进行地理查询。当我设置 post 的 geohash 时,我是这样做的 if let geoHash = GFGeoHash(location: location.coordinate).geoHashValue {

但是,为了使 geohash 查询不那么具体,我计划在查询时截断部分 geohash;目前,查询看起来类似于此

 var geoQuerySpecific = GFGeoHashQuery()
        let geoQueryHash =  GFGeoHashQuery.queries(forLocation: (lastLocation?.coordinate)!, radius: (30)) as! Set<GFGeoHashQuery>

        for query in geoQueryHash {
            geoQuerySpecific = query
            print("the key is this um \(geoQuerySpecific)")
        }
        print("the starting value is \(geoQuerySpecific.startValue)  and the end value is \(geoQuerySpecific.endValue)")
        let nearQuery = Firestore.firestore().collection("stuff").order(by: "g").whereField("g", isGreaterThanOrEqualTo: geoQuerySpecific.startValue).whereField("g", isLessThanOrEqualTo: geoQuerySpecific.endValue)

如您所见,这将无法正常工作,因为 geoQueryHash 中有多个项目。当我在 firebase 中设置它时,我考虑过从 geohash 中截断最后四个 digits/letters,但是,这不够具体。要获得最接近的 posts,最好像我现在一样在数据库中设置 geoHashes,然后,在检索内容时, 使起始值成为查询最具体的 geohash然后使最终值成为 geohash 的截断版本,以获取最接近的 posts 开始并以最广泛的结束?

我可以将 Firestore 查询限制为 50,这样我就可以检索从最近到最远的 50 posts...我对地理哈希的理解是否正确?这可行吗?

理论上,如果有一种方法可以将 geohashes 存储为整数,那么我可以使 firestore 查询从最大整数(即最精确的 Geohash)开始,然后通过降序对查询进行排序,直到达到最不精确intenser(最广泛的 geoHash),然后将其限制为 50。

GeoFirestore 使用 geohashes 能够 select geohashes 范围内的文档,这与地图上的区域大致相同。仅使用地理查询无法从该区域内检索指定顺序内的那些文档。如果您想按距离对文档进行排序,则必须在地理查询之后在您的应用程序代码中执行此操作。

如果您想了解更多原因,请看一下我刚才的演讲:Querying Firebase and Firestore based on geographic location or distance。我在其中解释了 geohashes 的工作原理,它们如何允许您 select 特定地理范围内的文档,以及为什么您不能在 Firestore(或 Firebase 的原始实时数据库)上执行更复杂的查询。