Docs 菜单
Docs 主页
/
MongoDB Manual
/ / / /

$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 ] }

提示

另请参阅:

后退

$addToSet

在此页面上