通过ID匹配MongoDB集合项?

要按ID匹配收集项,请在MongoDB中使用$in。让我们创建一个包含文档的集合-

> db.demo528.insertOne({"Name":"Chris",Age:21});{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e8b00d2ef4dcbee04fbbbe0")
}
> db.demo528.insertOne({"Name":"Bob",Age:22});{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e8b00d9ef4dcbee04fbbbe1")
}
> db.demo528.insertOne({"Name":"David",Age:20});{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e8b00e0ef4dcbee04fbbbe2")
}

find()方法的帮助下显示集合中的所有文档-

> db.demo528.find();

这将产生以下输出-

{ "_id" : ObjectId("5e8b00d2ef4dcbee04fbbbe0"), "Name" : "Chris", "Age" : 21 }
{ "_id" : ObjectId("5e8b00d9ef4dcbee04fbbbe1"), "Name" : "Bob", "Age" : 22 }
{ "_id" : ObjectId("5e8b00e0ef4dcbee04fbbbe2"), "Name" : "David", "Age" : 20 }

以下是按ID匹配收集项的查询-

> db.demo528.find({
   _id: {$in:[ObjectId("5e8b00d2ef4dcbee04fbbbe0"),ObjectId("5e8b00e0ef4dcbee04fbbbe2")]}
});

这将产生以下输出-

{ "_id" : ObjectId("5e8b00d2ef4dcbee04fbbbe0"), "Name" : "Chris", "Age" : 21 }
{ "_id" : ObjectId("5e8b00e0ef4dcbee04fbbbe2"), "Name" : "David", "Age" : 20 }