gpt4 book ai didi

node.js - Mongoose 排序嵌套的对象数组不起作用

转载 作者:行者123 更新时间:2023-12-04 15:25:24 25 4
gpt4 key购买 nike

我是 NodeJS 和 MongoDB 的新手,当我想使用 Mongoose 执行带有 Sort() 的 Find() 查询时遇到问题。

我想按通知日期对我的结果进行排序,但它不起作用

这是我的查询:

UsersNotifications
.find({user_id: new ObjectId(req.user._id)})
.sort({'notifications.date': -1})
.select('notifications').exec().then(usersNotifications => {
res.locals.usersNotifications = usersNotifications;
});

这是我的模型:

enter image description here

感谢您的帮助!

最佳答案

Afaik 你不能按嵌套对象排序,但你可以 unwind notifications 数组,应用降序排序并重新组合结果。像这样的东西:

.aggregate([
{ $match: { _id: new ObjectId(req.user._id) }},
{ $unwind: '$notifications' },
{ $sort: { 'notifications.date': -1 }},
{ $group: { _id: '$_id', notifications: { $push: '$notifications'}}}])

关于node.js - Mongoose 排序嵌套的对象数组不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62345528/

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