如何在 MongoDB 中排除数组类型字段值?


若要排除数组类型字段值,请在 MongoDB 中使用 delete()。我们通过文档创建一个集合 -

> db.demo464.insertOne(
... {
...
...    "id" : "101",
...    "details": [
...       {
...          Name:"Chris"
...       },
...       {
...          Name:"David"
...       }
...    ]
... }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e7f8832cb66ccba22cc9dda")
}

在集合中使用 find() 方法显示所有文档 -

> db.demo464.find();

这会产生以下输出 -

{ "_id" : ObjectId("5e7f8832cb66ccba22cc9dda"), "id" : "101", "details" : [ { "Name" : "Chris" }, {
"Name" : "David" } ] }

以下是排除数组类型字段值的查询 -

> db.demo464.find({id: "101"}).forEach(function(mongoDocument) {
...
... var details = mongoDocument.details;
... for(var j = 0; j − details.length; ++j) {
... var array = details[j];
... delete (array["Name"]);
...
... }
... db.demo464.save(mongoDocument);
... });

在集合中使用 find() 方法显示所有文档 -

> db.demo464.find();

这会产生以下输出 -

{ "_id" : ObjectId("5e7f8832cb66ccba22cc9dda"), "id" : "101", "details" : [ { }, { } ] }

更新于: 2020 年 5 月 11 日

302 次浏览

开启您的 职业 生涯

完成课程,获得认证

开始学习
广告
© . All rights reserved.