清除嵌套MongoDB数组中的项目?
要清除嵌套数组中的项目,请使用$set运算符。让我们首先创建一个集合。以下是使用文档创建集合的查询
> db.clearingItemsInNestedArrayDemo.insertOne( {...
... "StudentName" : "John",
... "StudentDetails" : [
... {
... "ProjectName" : "Online Banking",
... "ProjectDetails" : [
... {
... "TechnologyUsed" : "Java",
... "TeamSize":5
... },
...
... ]
... }
... ]
... }
... );
{
"acknowledged" : true,
"insertedId" : ObjectId("5c9930b4330fd0aa0d2fe4ce")
}
以下是在find()
方法的帮助下显示集合中所有文档的查询
> db.clearingItemsInNestedArrayDemo.find().pretty();
这将产生以下输出
{"_id" : ObjectId("5c9930b4330fd0aa0d2fe4ce"),
"StudentName" : "John",
"StudentDetails" : [
{
"ProjectName" : "Online Banking",
"ProjectDetails" : [
{
"TechnologyUsed" : "Java",
"TeamSize" : 5
}
]
}
]
}
以下是清除嵌套数组中的项目的查询
> db.clearingItemsInNestedArrayDemo.update({"StudentName": "John"}, {"$set": {"StudentDetails": []}});Updated 1 existing record(s) in 4ms
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
现在,再次检查集合中的文档,以验证是否已从嵌套数组中清除了这些项目。以下是查询
> db.clearingItemsInNestedArrayDemo.find().pretty();
这将产生以下输出
{"_id" : ObjectId("5c9930b4330fd0aa0d2fe4ce"),
"StudentName" : "John",
"StudentDetails" : [ ]
}
以上是 清除嵌套MongoDB数组中的项目? 的全部内容, 来源链接: utcz.com/z/338504.html