要清除嵌套数组中的项目,请使用$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" : [ ]
}