因此,我希望在mongodb上使用runCommand执行geoNear,并且希望结果按日期排序。
我知道怎么做第一部分
db.users.runCommand({'geoNear' :"users",'near' : [-76.483999, 42.402794], 'spherical' : true, 'maxDistance' : 20/6378 })
但是,如何才能得到按created_at排序的结果呢?如果我使用Mongo gem来执行此操作,则查询将如下所示
User.database.command({'geoNear'=>"users",'near' => [-122, 37]}, 'spherical' => true, 'maxDistance' => 20/6378)
不过,我不知道如何按日期对其进行排序。在这种情况下,我正在考虑在created_at上使用索引。我在location和created_at上都有索引,但结果仍然没有按created_at日期的顺序返回。有没有人知道该怎么做?
发布于 2012-01-08 16:28:04
根据链接,我认为不可能在geonear命令中添加排序
查询的有效选项包括:“
”、"num“、"maxDistance”、"distanceMultiplier“和"query”。
默认情况下,它按距离排序。
或者,您可以像这样编写您的球形查询
db.users.find( { loc : { $nearSphere : [80.21223299999997, 13.034892],$maxDistance:20/6378 } } ).sort({ created_at : -1 } ) //-1 for descending您的ruby mongomapper等效项可能是(不确定,最好验证一下)
Users.where(:loc => {'$nearSphere' => [-122, 37],'$maxDistance'=>20/6378 }).sort(:created_at.desc)https://stackoverflow.com/questions/8774875
复制相似问题