MongoDB 删除文档的方式(删除一个、批量删除)

2023-12-08 0 949
目录
  • MongoDB 删除文档(删除一个、批量删除)
    • 一、删除一个文档
    • 二、删除多个文档
    • 三、删除文档

MongoDB 删除文档(删除一个、批量删除)

MongoDB中提供了三种删除文档的方式,如下:

删除一个文档:db.collection.deleteOne(filter, options)

删除多个文档:db.collection.deleteMany(filter, options)

删除文档:db.collection.remove(filter, options)

下面我们对三种方式分别进行介绍:

一、删除一个文档

语法:db.collection.deleteOne(filter, options)

如果有多个匹配的文档,也只会删除一个文档。

例子:

查询所有的文档:

{ \”_id\” : \”1001\”, \”name\” : \”张三2\”, \”fruits\” : [ \”apple\”, \”orange\” ], \”updateTime\” : ISODate(\”2023-04-06T02:36:00.703Z\”) }
{ \”_id\” : \”1002\”, \”name\” : \”李四\”, \”fruits\” : [ \”banana\”, \”apple\” ] }
{ \”_id\” : \”1003\”, \”name\” : \”王五\”, \”fruits\” : [ \”banana\”, \”apple\”, \”orange\” ] }
{ \”_id\” : \”1004\”, \”commet\” : \”我的内容被替换了\” }
{ \”_id\” : \”1005\”, \”name\” : \”田七\”, \”score\” : 100, \”fruits\” : [ \”banana\” ] }

下面我们删除fruits中包含apple的文档:

db.test.deleteOne({ \”fruits\”: \”apple\” })

执行后我们再查询所有的文档:

{ \”_id\” : \”1002\”, \”name\” : \”李四\”, \”fruits\” : [ \”banana\”, \”apple\” ] }
{ \”_id\” : \”1003\”, \”name\” : \”王五\”, \”fruits\” : [ \”banana\”, \”apple\”, \”orange\” ] }
{ \”_id\” : \”1004\”, \”commet\” : \”我的内容被替换了\” }
{ \”_id\” : \”1005\”, \”name\” : \”田七\”, \”score\” : 100, \”fruits\” : [ \”banana\” ] }

发现只有包含apple的文档中,只有一个文档被删除了。

二、删除多个文档

语法:db.collection.deleteMany(filter, options)

删除所有匹配的文档

例子:

下面我们删除fruits中包含apple的文档:

db.test.deleteMany({ \”fruits\”: \”apple\” })

执行后我们再查询所有的文档:

{ \”_id\” : \”1004\”, \”commet\” : \”我的内容被替换了\” }
{ \”_id\” : \”1005\”, \”name\” : \”田七\”, \”score\” : 100, \”fruits\” : [ \”banana\” ] }

发现包含apple的文档全部都被删除了。

三、删除文档

语法:db.collection.remove(filter, options)

options中提供了一个 justOne 参数用于控制删除一个匹配的文档还是删除所有匹配的文档。

justOne默认值为false,会删除所有匹配的文档

设置成true,会删除匹配的一个文档。

例子:

我们尝试删除所有的文档:

db.test.remove({ })

执行后我们再查询所有的文档,会发现文档不存在,说明了 justOne的默认值为false.

我们再插入两条数据:

db.test.insertMany(
[
{
\”id\”: \”1002\”,
\”name\”: \”李四\”,
\”age\”: 22
},
{
\”id\”: \”1003\”,
\”name\”: \”王五\”,
\”age\”: 25
}
]
);

我们再尝试删除所有的文档,不过这次加上justOne: true的参数:

db.test.remove({ }, { \”justOne\”: true })

执行后我们再查询所有的文档:

{ \”_id\” : ObjectId(\”642f85506ca9e7fe3a3ff6f7\”), \”id\” : \”1003\”, \”name\” : \”王五\”, \”age\” : 25 }

从上面的文档结果来看,justOne: true参数下只会删除一条匹配的文档。

到此这篇关于MongoDB 删除文档(删除一个、批量删除)的文章就介绍到这了,更多相关MongoDB 删除文档内容请搜索悠久资源以前的文章或继续浏览下面的相关文章希望大家以后多多支持悠久资源!

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

悠久资源 MongoDB MongoDB 删除文档的方式(删除一个、批量删除) https://www.u-9.cn/database/mongodb/128653.html

常见问题

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务