如何在 MongoDB 中使用数组字段匹配全部内容?


要在 MongoDB 中匹配全部内容,请使用 $all。$all 运算符选择字段值为数组的文档,该数组包含所有指定元素。让我们创建一个文档集合 −

> db.demo695.insertOne({"ListOfValues":[100,200,500,800]});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5ea6d4c4551299a9f98c938f")
}
> db.demo695.insertOne({"ListOfValues":[1000,200,4000]});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5ea6d4cf551299a9f98c9390")
}

通过 find() 方法从集合中显示所有文档 −

> db.demo695.find();

这将产生以下输出 −

{ "_id" : ObjectId("5ea6d4c4551299a9f98c938f"), "ListOfValues" : [ 100, 200, 500, 800 ] }
{ "_id" : ObjectId("5ea6d4cf551299a9f98c9390"), "ListOfValues" : [ 1000, 200, 4000 ] }

以下是使用数组字段和匹配全部内容的查询 −

> db.demo695.find({"ListOfValues":{$all:[1000,200,4000]}});

这将产生以下输出 −

{ "_id" : ObjectId("5ea6d4cf551299a9f98c9390"), "ListOfValues" : [ 1000, 200, 4000 ] }

更新于: 14-5 月-2020

163 次浏览

开启您的 职业生涯

完成课程获得认证

开始
广告