node.js - 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 }));
解决方案
我认为这应该有效。
可以使用此查询更新单人游戏:-
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 更新数组内的正确卡片。
推荐阅读
- python - 在 Python 中确定字符串的编码
- c# - c# microsoft.graph SDK 将消息复制到另一个邮箱
- php - 如何在路由中选择一个 id 将其传递到控制器并针对该 id 获取数据并在 laravel 5.6 中再次重定向它
- python - AttributeError:模块“多处理”没有属性“事件”
- amazon-web-services - API 网关 URL 路径参数未通过
- ios - 无法从 XCode 9.2 上所需的二进制 CoreLocation.framework 进行符号化
- mysql - 如何让 Django 模型中的 id 自动增加 2?
- android - 混淆(minifyEnabled true)在调试和发布中不起作用
- c# - 在多个 OR 条件下连接表
- c# - 识别 IEnumerable 是否已排序的方法