MongoDB删除操作(Delete)

本文将介绍MongoDB删除操作(Delete),即 db.collection.deleteOne() 和 db.collection.deleteMany() 方法。

删除操作从集合中删除文档。MongoDB提供了以下删除集合文档的方法:

  • db.collection.deleteOne() New in version 3.2

  • db.collection.deleteMany() New in version 3.2

在MongoDB中,删除操作以单个集合为目标。MongoDB中的所有写操作都是单个文档级别上的原子操作。可以指定过滤器去筛选要删除的文档,这些过滤器使用与读取操作相同的语法。下面的示例使用 invertory 集合。若要填充 invertory 集合,请运行以下命令:

# 切换到 test 数据库
use test

# 导入数据到 inventory 集合
db.inventory.insertMany( [
   { item: "journal", qty: 25, size: { h: 14, w: 21, uom: "cm" }, status: "A" },
   { item: "notebook", qty: 50, size: { h: 8.5, w: 11, uom: "in" }, status: "P" },
   { item: "paper", qty: 100, size: { h: 8.5, w: 11, uom: "in" }, status: "D" },
   { item: "planner", qty: 75, size: { h: 22.85, w: 30, uom: "cm" }, status: "D" },
   { item: "postcard", qty: 45, size: { h: 10, w: 15.25, uom: "cm" }, status: "A" },
] );

删除所有文档

若要从集合中删除所有文档,请将空筛选文档 {} 传递给 db.collection.deleteMany() 方法。以下示例从 invertory 集合中删除所有文档:

db.inventory.deleteMany({})

该方法返回具有操作状态的文档。

删除与条件匹配的所有文档

你通过指定规则或过滤器去删除匹配的所有文档。过滤器使用与读取操作相同的语法。若要指定相等条件,请在查询筛选文档中使用 <filed>:<value> 表达式。如下:

{ <field1>: <value1>, ... }

查询筛选器文档可以使用查询运算符以下列形式指定条件:

{ <field1>: { <operator1>: <value1> }, ... }

若要删除与删除条件匹配的所有文档,请将筛选器参数传递给 deleteMany() 方法。

下面的示例从 inventory 集合中删除 status 字段等于 “A” 的所有文档:

db.inventory.deleteMany({ status : "A" })

该方法返回具有操作状态的文档。

只删除一个与条件匹配的文档

若要删除最多与指定筛选器匹配的单个文档 (即使多个文档可能与指定的筛选器匹配),请使用 db.Collection.delteOne() 方法。以下示例删除 status 为 “D” 的第一个文档:

db.inventory.deleteOne( { status: "D" } )

删除行为

索引(Indexes)

删除操作不会删除索引,即使从集合中删除所有文档也是如此。

原子性(Atomicity)

MongoDB 中的所有写操作都是单个文档级别上的原子操作。

写确认(Write Acknowledgement)

与写有关,您可以指定 MongoDB 请求写入操作的确认级别。

如果在胜利前却步,往往只会拥抱失败;如果在困难时坚持,常常会获得新的成功。
0 不喜欢
说说我的看法 -
全部评论(
没有评论
关于
本网站专注于 Java、数据库(MySQL、Oracle)、Linux、软件架构及大数据等多领域技术知识分享。涵盖丰富的原创与精选技术文章,助力技术传播与交流。无论是技术新手渴望入门,还是资深开发者寻求进阶,这里都能为您提供深度见解与实用经验,让复杂编码变得轻松易懂,携手共赴技术提升新高度。如有侵权,请来信告知:hxstrive@outlook.com
公众号