15、MongoDB 删除文档

在前面一章节中我们学习了如何向文档中插入数据,现在我们来学习如何在删除 MongoDB 集合

remove() 方法

MongoDB remove() 方法是用来删除集合中的数据

语法

remove() 方法语法格式如下

> db.collection.remove(
   <query>,
   <justOne>
)

在运行 remove() 函数前先执行 find() 命令来判断执行的条件是否正确,这是一个良好的习惯

参数说明

参数 说明
query 必选。删除的文档的条件
justOne 可选。如果设为 true 或 1,则只删除一个文档

如果MongoDB 是 2.6 版本以后的,语法格式如下

> db.collection.remove(
   <query>,
   {
     justOne: <boolean>,
     writeConcern: <document>
   }
)

参数说明

参数 说明
query 可选。删除的文档的条件
justOne 可选。如果设为 true 或 1,则只删除一个文档
writeConcern 可选。抛出异常的级别

范例

首先我们执行 insert() 方法 3 次插入 3 条数据

> db.lession.insert({title: 'MongoDB 基础教程', 
  by: 'penglei',
  favorite: 1000000
})
WriteResult({ "nInserted" : 1 })
> db.lession.insert({title: 'MongoDB 基础教程', 
  by: 'penglei',
  favorite: 1000000
})
WriteResult({ "nInserted" : 1 })
> db.lession.insert({title: 'MongoDB 基础教程', 
...   by: 'penglei',
...   favorite: 1000000
... })
WriteResult({ "nInserted" : 1 })

接着使用 find() 函数查询数据

> db.lession.find().pretty()
{
  "_id" : ObjectId("59edadf7c3ba87608db0fe4e"),
  "title" : "MongoDB 基础教程",
  "by" : "penglei",
  "favorite" : 1000000
}
{
  "_id" : ObjectId("59edadf8c3ba87608db0fe4f"),
  "title" : "MongoDB 基础教程",
  "by" : "penglei",
  "favorite" : 1000000
}
{
  "_id" : ObjectId("59edae8ac3ba87608db0fe50"),
  "title" : "MongoDB 基础教程",
  "by" : "penglei",
  "favorite" : 1000000
}
> 

现在我们来移除 一 条 by 为 ‘penglei’ 的文档,需要设置 justOne 为 1

> db.lession.remove({'by':'penglei'},true)
WriteResult({ "nRemoved" : 1 })  # 删除了 1 条数据,还剩下两条
> db.lession.find()
{ "_id" : ObjectId("59edadf8c3ba87608db0fe4f"), "title" : "MongoDB 基础教程", "by" : "penglei", "favorite" : 1000000 }
{ "_id" : ObjectId("59edae8ac3ba87608db0fe50"), "title" : "MongoDB 基础教程", "by" : "penglei", "favorite" : 1000000 }

接下来我们删除剩下的两条

> db.lession.remove({'by':'penglei'})
WriteResult({ "nRemoved" : 2 })  # 删除了两条 
> db.lession.find()  # 数据库空了
> 

如果想删除所有数据,可以使用以下方式

> db.lession.remove({})