您必须执行 2 个单独的查询,
- 查找用户文档
- 检查书籍字段是否存在
- 如果存在则推送对象,否则设置新字段
var user_id = "user1";
var bookData = { id: 'book1', title: 'this is book1' };
// FIND USER DATA
var userData = await db.collection('userData').findOne({ user_id: user_id }, { books: 1 });
var updateBody = { $push: { books: bookData } };
// IF BOOKS FIELD NOT PRESENT THEN SET NEW
if (!userData.books) {
updateBody = { $set: { books: [bookData] } };
}
var updateData = await db.collection('userData').updateOne({ user_id: user_id }, updateBody);
console.log(updateData);
第二个选项,您可以使用从 MongoDB 4.2 开始的聚合管道更新,
$ifNull
检查字段是否为空,然后返回 []
$concatArrays
将当前books
与新书对象连接起来
var bookData = { id: 'book1', title: 'this is book1' };
db.collection('userData').update({
// put your condition
},
[{
$set: {
books: {
$concatArrays: [
{ $ifNull: ["$books", []] },
[bookData]
]
}
}
}],
{ multi: true }
);
操场