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