[英]Is there a way to update multiple documents with different values in mongoose?
[英]MongoDb mongoose aggregatePagination returns multiple same documents over different pages
我正面临着 mongodb 和 mongoose 的分页问题。 我正在尝试查询一组导师,并在分页和排序(按更新日期)结果中获取与查询匹配的导师。 但事实是我在不同的页面上得到多个相同的文档......我希望它返回一组独特的文档。 这是我的功能的一部分(其余部分只是从请求正文构建查询):
exports.search = (req, res) => {
var options = { page: page, limit: perPage, sortBy: { updatedDate: -1 }}
const aggregate = Tutor.aggregate([
{
"$geoNear":
{
"near":
{
"type": "Point",
"coordinates": [lon1, lat1]
},
"distanceField": "distance",
"spherical": true,
"maxDistance": radius
}
},
{
$match: match
}
]);
Tutor
.aggregatePaginate(aggregate, options, function (err, result, pageCount, count) {
if (err) {
return res.status(400).send(err);
}
else {
var opts = [
{ path: 'levels', select: 'name' },
{ path: 'subjects', select: 'name' },
{ path: 'assos', select: 'name' }
];
Tutor
.populate(result, opts)
.then(result2 => {
return res.send({
page: page,
perPage: perPage,
pageCount: pageCount,
documentCount: count,
tutors: result2
});
})
.catch(err => {
return res.status(400).send(err);
});
}
})
};
现在,假设我正在查询第 1 页,每页限制为 8。我已经正确取回了我的 8 个文档,所有文档都不同。 但是当我查询第 2 页时,每页具有相同的限制,一半的文档已经在第 1 页中返回! 你知道为什么会这样吗? 谢谢 !
编辑
我认为是sortBy让它发生了。 如果我删除它,一切正常。 虽然我需要它...
经过大量研究。 我找到了这个解决方案。 希望它能解决你的问题。
Jobs.aggregatePaginate(aggregateQuery, { page: 1, limit: 10, sort: { 'createdAt': 'desc' } }, function (){});
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.