首页 > 解决方案 > Mongoose如何一次调用更新不同文档中的多个子文档 - MERN堆栈

问题描述

我想通过 mongoose 进行 API 调用,以将一批选定Players(下面的模式)cards子文档的日期字段更新为当前日期。

播放器架构:

const playerSchema = new Schema({
  name: String,
  cards: [{
    date: { type: Date, required: true },
    note: String
  }],
});

我创建了一个复选框,用户可以在其中选择多个Players(以及从他们的cards数组中选择一个特定的“卡片”子文档),并将所有选定卡片的日期更改为相同Players。在反应中,我在正文中将相应的 ObjectId 批处理在一起,并将选定的玩家/卡片组合发送到如下所示的对象数组中(其中数字表示相同的分组玩家和卡片子文档 ObjectId):

我发送到服务器的数组(可通过 req.body.cards 访问):

[ {cardId: card1._id, playerId: player1._id},
  {cardId: card2._id, playerId: player2._id},
  {cardId: card3._id, playerId: player3._id} ]

在我的 Node/Express 服务器put路由中,我将如何更新所有这些玩家和他们的特定卡片并异步给他们所有相同的日期 (Date.now())?换句话说,我将如何正确迭代所有不同的 playerId 和它们各自的 cardId(最好没有任何外部库)?

以下是我在常规放置路径中为单个玩家更新单张卡片以编辑cards子文档的方式:

Player.findById(playerId)
  .then(player => {
    const card = player.cards.id(cardId);
    card.date = Date.now();

    player.save(
      (err, updatedCard) =>
        err
          ? console.log("Error in update card: " + err)
          : res.send(updatedCard)
    );
  })
  .catch(err => res.status(404).json({ success: false }));

标签: node.jsmongodbexpressmongoose

解决方案


我认为这应该有效。

可以使用此查询更新单人游戏:-

Player.findOneAndUpdate(
  { _id: playerId, "cards._id": cardId },
  { $set: { "cards.$.date": Date.now() } }
);

可以使用此查询更新多个玩家

Player.update(
  { $or: [{ _id: player1Id, "cards._id": card1Id }, { _id: player2Id, "cards._id": card2Id }, { _id: player3Id, "cards._id": card3Id }] },
  { $set: { "cards.$.date": Date.now() } },
  { multi: true }
);

位置运算符 $ 将负责使用给定的卡片 ID 更新数组内的正确卡片。


推荐阅读