根据 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 }

更新日期:2020-05-13

396 浏览

启动您的 职业生涯

完成课程,获得认证

开始学习
广告