十五、MongoDB 删除文档

十五、MongoDB 删除文档

master ,这是我的小站,欢迎访问哦~~

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

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

remove() 方法

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

语法

remove() 方法语法格式如下

1
2
3
4
> db.collection.remove(
<query>,
<justOne>
)

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

参数说明

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

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

1
2
3
4
5
6
7
> db.collection.remove(
<query>,
{
justOne: <boolean>,
writeConcern: <document>
}
)

参数说明

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

范例

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
> db.lession.insert({title: 'MongoDB 基础教程', 
by: 'b',
favorite: 1000000
})
WriteResult({ "nInserted" : 1 })
> db.lession.insert({title: 'MongoDB 基础教程',
by: 'b',
favorite: 1000000
})
WriteResult({ "nInserted" : 1 })
> db.lession.insert({title: 'MongoDB 基础教程',
... by: 'b',
... favorite: 1000000
... })
WriteResult({ "nInserted" : 1 })

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
> db.lession.find().pretty()
{
"_id" : ObjectId("59edadf7c3ba87608db0fe4e"),
"title" : "MongoDB 基础教程",
"by" : "b",
"favorite" : 1000000
}
{
"_id" : ObjectId("59edadf8c3ba87608db0fe4f"),
"title" : "MongoDB 基础教程",
"by" : "b",
"favorite" : 1000000
}
{
"_id" : ObjectId("59edae8ac3ba87608db0fe50"),
"title" : "MongoDB 基础教程",
"by" : "b",
"favorite" : 1000000
}
>

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

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

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

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

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

1
> db.lession.remove({})