清除嵌套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" : [ ] }