$pop
定义
行为
从 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 ] }