Javascript Node.js Mongo使用$position,而$push不使用';I don’我没有按预期工作
我对Node.js或Mongo没有那么丰富的经验,所以请原谅我在发布本文时可能出现的任何错误 我有一个如下所示的模式:Javascript Node.js Mongo使用$position,而$push不使用';I don’我没有按预期工作,javascript,node.js,mongodb,Javascript,Node.js,Mongodb,我对Node.js或Mongo没有那么丰富的经验,所以请原谅我在发布本文时可能出现的任何错误 我有一个如下所示的模式: var MessagesSchema = new mongoose.Schema({ title: { type: String, default: "Untitled Message Group" }, members: { type: Array }, unreadCounts: {
var MessagesSchema = new mongoose.Schema({
title: {
type: String,
default: "Untitled Message Group"
},
members: {
type: Array
},
unreadCounts: {
type: Array
},
admins: {
type: Array
},
messages: {
sender: {
type: String
},
content: {
type: String
},
date: {
type: Number
}
}
});
来自用户的新消息被发送到“messages”部分,他们的信息被放入“sender”、“content”和“date”数组。我试图让它一次只加载一定数量的消息,您可以单击“加载更多”按钮加载更多消息。这是可行的,但是我的数组是向后的,旧消息先加载,最新消息最后加载。所以,我试图使它,所以我反向数组作为数据输入。以下是我对$push-ing的旧方法:
Messages.updateOne({
'_id': ObjectId(data[2])
}, {
$push: {
messages: {
sender: data[1],
content: data[0],
date: Date.now()
}
},
$inc: {
"unreadCounts.$[]": 1
}
}, function (err, result) {
//...
});
以下是我尝试的新方法:
Messages.updateOne({
'_id': ObjectId(data[2])
}, {
$push: {
messages: {
$each: [{sender: data[1], content: data[0], date: Date.now()}],
$position: 0
}
},
$inc: {
"unreadCounts.$[]": 1
}
}, function (err, result) {
//...
});
下面是其中一些数据的示例:
{
"_id": ObjectId("5ce4990a11fa8f0d6e27344a"),
//...
//Other stuff
//...
"messages": [{
"sender": "5c4ba709701212087e4d1bc9",
"content": "1st message sent",
"date": 1558485260497
}, {
"sender": "5c4ba709701212087e4d1bc9",
"content": "2nd message sent",
"date": 1558485261095
}, {
"sender": "5c4ba709701212087e4d1bc9",
"content": "3rd message sent",
"date": 1558485261446
}]
}
第三条消息是最后发送的消息。我希望顺序是相反的:第三条消息将在顶部,然后是第二条消息,然后是第一条消息
然而,出于某种原因,使用$position似乎不起作用。项目被推送到数组的末尾,而不是像预期的那样放在数组的开头
有人知道他们能不能帮我找出原因吗?也许我只是犯了个愚蠢的错误?提前谢谢 希望这有助于:
型号:
var MessagesSchema = new mongoose.Schema({
title: {
type: String,
default: "Untitled Message Group"
},
members: {
type: Array
},
unreadCounts: {
type: Array
},
admins: {
type: Array
},
messages: [{
sender: {
type: String
},
content: {
type: String
},
date: {
type: Number
}
}]
});
现有数据:
{
"_id" : ObjectId("5ce4990a11fa8f0d6e27344a"),
"messages" : [
{
"sender" : "5c4ba709701212087e4d1bc9",
"content" : "1st message sent",
"date" : 1558485260497
},
{
"sender" : "5c4ba709701212087e4d1bc9",
"content" : "2nd message sent",
"date" : 1558485261095
},
{
"sender" : "5c4ba709701212087e4d1bc9",
"content" : "3rd message sent",
"date" : 1558485261446
}
]
}
查询:
db.messages.updateOne({
"_id": ObjectId("5ce4990a11fa8f0d6e27344a")
},{
$push: {
messages: {
$each: [{sender:"5c4ba709701212087e4d1bc9" , content: "4th message sent", date: Date.now()}],
$sort: {date: -1}
}
}
})
查询结果后:
{
"_id" : ObjectId("5ce4990a11fa8f0d6e27344a"),
"messages" : [
{
"sender" : "5c4ba709701212087e4d1bc9",
"content" : "4th message sent",
"date" : 1558575451749
},
{
"sender" : "5c4ba709701212087e4d1bc9",
"content" : "3rd message sent",
"date" : 1558485261446
},
{
"sender" : "5c4ba709701212087e4d1bc9",
"content" : "2nd message sent",
"date" : 1558485261095
},
{
"sender" : "5c4ba709701212087e4d1bc9",
"content" : "1st message sent",
"date" : 1558485260497
}
]
}
架构中的消息是数组还是对象?你能用一些现有数据和预期结果更新这个问题吗?@the_mahasagar我已经添加了一些现有数据。我希望这能把事情弄清楚。谢谢你的主意,但似乎没有什么不同。项目仍然添加到数组的末尾。我已经用查询输出更新了答案!这是你想要的吗?问题是在一个消息是对象的模型中!您需要更改的是数组。我更新了答案,修改了模型。太棒了,非常感谢。我使用的$push方法很好,但问题是我需要将模型中的消息从对象更改为数组。我没有意识到在定义它们时有什么不同,我对这一点还不熟悉。非常感谢。