Docs 菜单

Docs 主页开发应用程序MongoDB Manual

$pop

在此页面上

  • 定义
  • 行为
  • 举例
$pop

$pop操作符删除数组的第一个或最后一个元素。向$pop传递值-1以删除数组的第一个元素,向1传递值以删除数组的最后一个元素。

$pop操作符的形式为:

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

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

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

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

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

从 MongoDB5 0mongod$pop{ }开始。当您将 等更新操作符与空操作数表达式 ( ) 一起使用时, 、 不再引发错误。空更新不会导致任何更改,也不会创建 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 ] } )

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

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

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

{ _id: 10, scores: [ 9 ] }

提示

另请参阅:

← $addToSet
$pull →

在此页面上