如何从MongoDB文档中的数组中删除字符串?
您可以使用$pull运算符从数组中删除字符串。首先让我们创建一个包含文档的集合-
> db.removeAStringDemo.insertOne({"Score":[45,67,89,"John",98,99,67]});
{
"acknowledged" : true,
"insertedId" : ObjectId("5cda5224b50a6c6dd317adbd")
}以下是在find()方法的帮助下显示集合中所有文档的查询-
> db.removeAStringDemo.find().pretty();
这将产生以下输出-
{
"_id" : ObjectId("5cda5224b50a6c6dd317adbd"),
"Score" : [
45,
67,
89,
"John",
98,
99,
67
]
}以下是从MongoDB文档中的数组中删除字符串的查询。要删除的字符串是“John”-
> db.removeAStringDemo.update( { _id :ObjectId("5cda5224b50a6c6dd317adbd") }, { $pull: { "Score":"John" }});
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })让我们再次检查文档-
> db.removeAStringDemo.find().pretty();
这将产生以下输出-
{
"_id" : ObjectId("5cda5224b50a6c6dd317adbd"),
"Score" : [
45,
67,
89,
98,
99,
67
]
}