节点.js mongo 在$push时使用 $position 无法按预期工作



我对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
        }
    }
});

来自用户的新消息将发送到"消息"部分,并将其信息放入"发送者","内容"one_answers"日期"数组中。我正在尝试做到这一点,以便一次只加载一定数量的消息,您可以单击"加载更多"按钮以加载更多消息。这是有效的,但是我的数组是向后的,旧消息首先加载,最新消息最后加载。因此,我正在尝试做到这一点,因此我在数据输入时将数组反转。这是我对$ 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
    }]
}

第三消息是发送的最后一条消息。我想逆转命令:第三消息将在顶部,然后是第二个消息,然后是第一个。

但是,由于某种原因,使用$位置似乎不起作用。物品被推到阵列的末端,而不是按预期放置在开始。

有人知道他们是否可以帮助我弄清楚为什么?也许我只是犯了一个愚蠢的错误?预先感谢!

希望这会有所帮助:$ push

模型:

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
    }
 ]
}

最新更新