1.$set

$set是MongoDB中的一个更新操作符,用于将一个字段的值设置为一个特定的值,或者创建一个新的字段并赋值。它的基本语法如下:

{ $set: { <field1>: <value1>, ... } }

其中,$set是操作符,<field1>是字段名,<value1>是字段的值。可以同时更新多个字段。

示例:

假设有一个名为users的集合,其中包含如下文档:

{ "_id" : ObjectId("617c9e34e9f68a131c8d18db"), "name" : "Alice", "age" : 25 }

现在我们想要将这个文档中的name字段更新为Bob,则可以使用如下的$set操作:

db.users.updateOne(
   { _id: ObjectId("617c9e34e9f68a131c8d18db") },
   { $set: { name: "Bob" } }
)

执行完毕后,users集合中的文档将变为:

{ "_id" : ObjectId("617c9e34e9f68a131c8d18db"), "name" : "Bob", "age" : 25 }

注意,如果更新的字段不存在,则会自动创建一个新的字段。例如,我们可以将上面的操作改成:

db.users.updateOne(
   { _id: ObjectId("617c9e34e9f68a131c8d18db") },
   { $set: { age: 30 } }
)

执行完毕后,users集合中的文档将变为:

{ "_id" : ObjectId("617c9e34e9f68a131c8d18db"), "name" : "Bob", "age" : 30 }

注意到,这次我们没有修改name字段,而是创建了一个新的age字段,并将其值设置为30。

$push

$push 是 MongoDB 中的一个更新操作符,用于将值添加到数组中。

它的语法如下:

{ $push: { <field1>: <value1>, ... } }

其中:

  • $push: 操作符,表示对数组进行添加操作。
  • <field1>:要添加到的字段名,必须是数组类型。
  • <value1>:要添加的值。

如果要添加多个值,可以这样写

{ $push: { <field1>: { $each: [ <value1>, <value2>, ... ] } } }

其中 $each 表示要添加的值是一个数组。

除了 $each,还有其他选项可以一起使用,比如 $slice$sort$position 等,可以更加灵活地控制数组的添加操作。

举个例子,假设我们有一个名为 books 的集合,其中每个文档都有一个 authors 字段,存储了书籍的作者信息。如果要将一位新作者 Jack 添加到某本书的作者列表中,可以这样写:

db.books.updateOne(
  { _id: ObjectId("...") },
  { $push: { authors: "Jack" } }
);

这将在指定的书籍文档中的 authors 数组末尾添加一个新元素 "Jack"

如果要添加多个作者,可以这样写:

db.books.updateOne(
  { _id: ObjectId("...") },
  { $push: { authors: { $each: [ "Jack", "Lucy", "Tom" ] } } }
);

这将在指定的书籍文档中的 authors 数组末尾添加三个新元素 "Jack""Lucy""Tom"

注意,如果要添加的值已经存在于数组中,它不会被重复添加。如果要强制添加重复的值,可以使用 $addToSet 操作符。