gpt4 book ai didi

mongodb - Geonear 按距离和时间排序

转载 作者:可可西里 更新时间:2023-11-01 09:59:02 29 4
gpt4 key购买 nike

我有以下数据:

{ 
"_id" : ObjectId("55a8c1ba3996c909184d7a22"),
"uid" : "1db82e8a-2038-4818-b805-76a46ba62639",
"createdate" : ISODate("2015-07-17T08:50:02.892Z"),
"palce" : "aa",
"sex" : 1,
"longdis" : 1,
"location" : [ 106.607312, 29.575281 ]
}
{
"_id" : ObjectId("55a8c1ba3996c909184d7a24"),
"uid" : "1db82e8a-2038-4818-b805-76a46ba62639",
"createdate" : ISODate("2015-07-17T08:50:02.920Z"),
"palce" : "bbb",
"sex" : 1,
"longdis" : 1,
"location" : [ 106.589896, 29.545098 ]
}
{
"_id" : ObjectId("55a8c1ba3996c909184d7a25"),
"uid" : "1db82e8a-2038-4818-b805-76a46ba62639",
"createdate" : ISODate("2015-07-17T08:50:02.922Z"),
"palce" : "ccc",
"sex" : 1,
"longdis" : 1,
"location" : [ 106.590758, 29.566713 ]
}
{
"_id" : ObjectId("55a8c1ba3996c909184d7a26"),
"uid" : "1db82e8a-2038-4818-b805-76a46ba62639",
"createdate" : ISODate("2015-07-17T08:50:02.923Z"),
"palce" : "ddd",
"sex" : 1,
"longdis" : 1,
"location" : [ 106.637039, 29.561436 ]
}
{
"_id" : ObjectId("55a8c1bc3996c909184d7a27"),
"uid" : "1db82e8a-2038-4818-b805-76a46ba62639",
"createdate" : ISODate("2015-07-17T08:50:04.499Z"),
"palce" : "eee",
"sex" : 1,
"longdis" : 1,
"location" : [ 106.539522, 29.57929 ]
}
{
"_id" : ObjectId("55a8d12e78292fa3837ebae4"),
"uid" : "1db82e8a-2038-4818-b805-76a46ba62639",
"createdate" : ISODate("2015-07-17T09:55:58.947Z"),
"palce" : "fff",
"sex" : 1,
"longdis" : 1,
"location" : [ 106.637039, 29.561436 ]
}

我想先按距离排序,如果距离相同,按时间排序。

我的命令:

db.runCommand( { 
geoNear: "paging",
near: [106.606033,29.575897 ],
spherical : true,
maxDistance : 1/6371,
minDistance:0/6371,
distanceMultiplier: 6371,
num:2,
query: {'_id': {'$nin': []}}
})

db.paging.find({
'location':{
$nearSphere: [106.606033,29.575897],
$maxDistance:1
}
}).limit(5).skip((2 - 1) * 2).sort({createdate:-1})

如何对“最近”和“创建日期”进行排序?

最佳答案

此处使用的正确查询使用 aggregation framework其中有 $geoNear 流水线阶段来协助这一点。它也是您唯一可以通过多个键“排序”的地方,不幸的是“地理空间”$nearSphere没有像 $text 这样的“距离”的“元”投影有一个“分数”。

还有 geoNear您正在使用的数据库命令也不能与“游标”一起使用 .sort()以那种方式。

db.paging.aggregate([
{ "$geoNear": {
"near": [106.606033,29.575897 ],
"spherical": true,
"distanceField": "distance",
"distanceMuliplier": 6371,
"maxDistance": 1/6371
}},
{ "$sort": { "distance": 1, "createdate": -1 } },
{ "$skip": ( 2-1 ) * 2 },
{ "$limit": 5 }
])

这等同于您正在尝试做的事情。

通过聚合框架,您可以使用 "pipeline operators"而不是“光标修饰符”来做像$sort这样的事情, $skip$limit .此外,这些必须按逻辑顺序排列,而游标修饰符通常会解决这个问题。

它是一个“管道”,就像“Unix 管道”一样。 |

此外,请注意“maxDistance”和“distanceMuliplier”。由于您的坐标是“旧坐标对”而不是 GeoJSON格式,则距离以“弧度”为单位测量。如果您有 GeoJSON 存储的位置数据,则结果以“米”为单位返回。

关于mongodb - Geonear 按距离和时间排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31475277/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com