如何在 MongoDB 中获取数组内的匹配文档?
要获取匹配的文档,请使用 $elemMatch。我们先使用文档创建一个集合 -
> db.getMatchingDocumentDemo.insertOne( { _id :1, "UserDetails":[ { "UserName":"John", "UserAge":23 } ] } ); { "acknowledged" : true, "insertedId" : 1 } > db.getMatchingDocumentDemo.insertOne( { _id :2, "UserDetails":[ { "UserName":"Larry", "UserAge":24 } ] } ); { "acknowledged" : true, "insertedId" : 2 }
以下是使用 find() 方法来显示来自集合的所有文档的查询 -
> db.getMatchingDocumentDemo.find().pretty();
这将产生以下输出 -
{ "_id" : 1, "UserDetails" : [ { "UserName" : "John", "UserAge" : 23 } ] } { "_id" : 2, "UserDetails" : [ { "UserName" : "Larry", "UserAge" : 24 } ] }
以下是获取 MongoDB 中数组中匹配文档的查询 -
> db.getMatchingDocumentDemo.find({UserDetails: {$elemMatch: {UserAge: 24}}});
这将产生以下输出 -
{ "_id" : 2, "UserDetails" : [ { "UserName" : "Larry", "UserAge" : 24 } ] }
广告