1

注意:检查密钥是否books存在,如果不存在则创建而不是更新它。

我正在使用带有 nodejs 的 mongodb 驱动程序。

db.collection('userData')文档中是这样的:

{ 
    user_id: 'user1',
    books: [{
               id: 'book1',
               title: 'this is book1'
    },
            {
               id: 'book1',
               title: 'this is book1'
    }]
}

插入新书条目时,如何检查文档中是否存在数组books,如果不存在则在文档中添加一个键books,然后插入书条目。

4

1 回答 1

1

您必须执行 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 }
);

操场

于 2021-04-23T10:08:43.400 回答