添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接
“文档” 菜单

$pop

$pop

$pop 操作符删除数组的第一个元素或最后一个元素。输入 $pop -1 的值,可以删除数组中的第一个元素,输入 1 则可以删除数组中的最后一个元素。

$pop 操作符具有如下形式:

{ $pop: { <field>: <-1 | 1>, ... } }

要在嵌入式文档或数组中指定 <field> ,请使用 点表示法。

从 MongoDB 5.0 开始,更新操作符按字典顺序处理具有基于字符串的名称的文档字段。具有数字名称的字段按数字顺序处理。详情请参阅 更新操作符行为

如果 <field> 不是数组,则 $pop 操作失败。

如果 $pop 操作符删除 <field> 中的最后一项,则 <field> 将保留一个空数组。

从 MongoDB 5.0 开始,使用带空操作数表达式 ( { } ) 的更新操作符(如 $pop )时, mongod 不会再引发错误。空更新不会导致任何变化,也不会创建 oplog 条目(意味着该操作为“无操作”)。

创建 students 集合:

db.students.insertOne( { _id: 1, scores: [ 8, 9, 10 ] } )

以下示例从 scores 数组中删除 第一个 元素 8:

db.students.updateOne( { _id: 1 }, { $pop: { scores: -1 } } )

第一个元素 8 已从 scores 数组中删除:

{ _id: 1, scores: [ 9, 10 ] }

将以下文档添加到 students 集合中:

db.students.insertOne( { _id: 10, scores: [ 9, 10 ] } )

以下示例通过在 $pop 表达式中指定 1 来从 scores 数组中删除 最后 一个元素 10:

db.students.updateOne( { _id: 10 }, { $pop: { scores: 1 } } )

最后一个元素 10 已从 scores 数组中删除:

{ _id: 10, scores: [ 9 ] }