我不擅長 MongoDB 高級技術。我在 mongo db 集合中的記錄
{
"_id": ObjectId("1"),
"manager": ObjectId("12345"),
"code": "PS",
"title": "Performance System",
"users": [
{
"_user": ObjectId("1"),
"role": "Member",
},
{
"_user": ObjectId("2"),
"role": "Member",
},
{
"_user": ObjectId("3"),
"role": "Member",
}
],
}
Node.js / ExpressJS
我創建了 API 來更新陣列,如下所示,但沒有奏效。
const updateProjectMember = asyncHandler(async (req, res) => {
const { userID, role } = req.body.userData;
try {
const project = await Project.updateMany(
{ _id: req.params.projectID },
{ $set: { "users.$[selectedUser].role": role } },
{ arrayFilters: { "selectedUser._user": { $in: userID } } }
);
res.status(200).json(project);
} catch (error) {
res.status(400);
throw new Error(error);
}
我使用 API 引數來獲取專案 ID。這里是請求正文資料
{
userID : ["2","3"];
role: "Admin"
}
因此 API 將獲取要匹配的用戶 ID 陣列,并將所有“角色”欄位設定為“管理員”以匹配所有內容。
我希望資料是這樣的
{
"_id": ObjectId("1"),
"manager": ObjectId("12345"),
"code": "PS",
"title": "Performance System",
"users": [
{
"_user": ObjectId("1"),
"role": "Member",
},
{
"_user": ObjectId("2"),
"role": "Admin",
},
{
"_user": ObjectId("3"),
"role": "Admin",
}
],
}
我在做正確的練習嗎?如果這是不好的做法,解決這個問題的最佳方法是什么。
uj5u.com熱心網友回復:
查詢沒問題。只需確保您傳遞的值與 MongoDB 檔案中的型別完全相同。
var mongoose = require('mongoose');
const updateProjectMember = asyncHandler(async (req, res) => {
const { userID, role } = req.body.userData;
userID = userID.map(x => mongoose.Types.ObjectId(x));
try {
const project = await Project.updateMany(
{ _id: mongoose.Types.ObjectId(req.params.projectID) },
{ $set: { "users.$[selectedUser].role": role } },
{ arrayFilters: { "selectedUser._user": { $in: userID } } }
);
res.status(200).json(project);
} catch (error) {
res.status(400);
throw new Error(error);
}
}
轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/447309.html
標籤:javascript mongodb api 表示 猫鼬
下一篇:更新陣列貓鼬中的字串
