MongoDB 删除文档
MongoDB remove() 方法是用来删除集合中的数据
在前面一章节中我们学习了如何向文档中插入数据,现在我们来学习如何在删除 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: 'yufei', favorite: 1000000 }) WriteResult({ "nInserted" : 1 }) > db.lession.insert({title: 'MongoDB 基础教程', by: 'yufei', favorite: 1000000 }) WriteResult({ "nInserted" : 1 }) > db.lession.insert({title: 'MongoDB 基础教程', ... by: 'yufei', ... favorite: 1000000 ... }) WriteResult({ "nInserted" : 1 })
接着使用 find() 函数查询数据
> db.lession.find().pretty() { "_id" : ObjectId("59edadf7c3ba87608db0fe4e"), "title" : "MongoDB 基础教程", "by" : "yufei", "favorite" : 1000000 } { "_id" : ObjectId("59edadf8c3ba87608db0fe4f"), "title" : "MongoDB 基础教程", "by" : "yufei", "favorite" : 1000000 } { "_id" : ObjectId("59edae8ac3ba87608db0fe50"), "title" : "MongoDB 基础教程", "by" : "yufei", "favorite" : 1000000 } >
现在我们来移除 一 条 by 为 'yufei' 的文档,需要设置 justOne 为 1
> db.lession.remove({'by':'yufei'},true) WriteResult({ "nRemoved" : 1 }) # 删除了 1 条数据,还剩下两条 > db.lession.find() { "_id" : ObjectId("59edadf8c3ba87608db0fe4f"), "title" : "MongoDB 基础教程", "by" : "yufei", "favorite" : 1000000 } { "_id" : ObjectId("59edae8ac3ba87608db0fe50"), "title" : "MongoDB 基础教程", "by" : "yufei", "favorite" : 1000000 }
接下来我们删除剩下的两条
> db.lession.remove({'by':'yufei'}) WriteResult({ "nRemoved" : 2 }) # 删除了两条 > db.lession.find() # 数据库空了 >
如果想删除所有数据,可以使用以下方式
> db.lession.remove({})