Javascript Node.js Mongo使用$position,而$push不使用';I don’我没有按预期工作

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: {

我对Node.js或Mongo没有那么丰富的经验,所以请原谅我在发布本文时可能出现的任何错误

我有一个如下所示的模式:

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方法很好,但问题是我需要将模型中的消息从对象更改为数组。我没有意识到在定义它们时有什么不同,我对这一点还不熟悉。非常感谢。