Bon*_*ard 3 javascript mongoose mongodb node.js
我试图通过从嵌套数组中删除一个对象来使用 mongoose 查找更新文档。我的目标文件如下:
user = {
"userId" : "myId",
"connections":
[{
"dateConnectedUnix": 1334567891,
"isActive": true,
"sessions": [
{"device": "mobile", "country": "US"},
{"device": "desktop", "country": "US"}
]
}, {
"dateConnectedUnix": 1334567893,
"isActive": false,
"sessions": [
{"device": "mobile", "country": "CA"},
{"device": "desktop", "country": "CA"}
]
}]
}
Run Code Online (Sandbox Code Playgroud)
这是我的尝试,但它没有更新文档:
Users.findOneAndUpdate({ "userId": "myId", "connections.dateConnectedUnix": 1334567891 },
{ $pull: { sessions: { device: "mobile" } } }, (err) => {
if (err) {
return res.status(404).json({ message: 'Error' });
}
return res.status(200).json({
success: true,
message: 'success'
});
}
);
Run Code Online (Sandbox Code Playgroud)
生成的文档应如下所示:
user = {
"userId" : "myId",
"connections":
[{
"dateConnectedUnix": 1334567891,
"isActive": true,
"sessions": [
{"device": "desktop", "country": "US"}
]
}, {
"dateConnectedUnix": 1334567893,
"isActive": false,
"sessions": [
{"device": "mobile", "country": "CA"},
{"device": "desktop", "country": "CA"}
]
}]
}
Run Code Online (Sandbox Code Playgroud)
基本上它是通过 id 找到用户,然后按日期找到连接,然后如果移动则删除设备。在我的特殊情况下,结果始终是一个匹配的文档和一个匹配的连接以及一个匹配的会话。
小智 6
因为您的会话数组在连接内
尝试“connections.$.sessions”而不是会话,这样你的查询就会是
Users.findOneAndUpdate({ "userId": "myId", "connections.dateConnectedUnix": 1334567891 },
{ $pull: { "connections.$.sessions" : { device: "mobile" } } }, (err) => {
if (err) {
return res.status(404).json({ message: 'Error' });
}
return res.status(200).json({
success: true,
message: 'success'
});
}
);
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3799 次 |
| 最近记录: |