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
操作符。