是否可以使用MongoDB查询数组对象中字段中具有特定值的条目?
是的,要使用MongoDB查询数组对象中的字段,请使用以下语法-
db.yourCollectionName.find({"yourOuterFieldName": { $elemMatch: { "yourInnerFieldName": "yourValue" } } } ).pretty();为了理解上述概念,让我们用文档创建一个集合。使用文档创建集合的查询如下-
> db.objectInAnArrayDemo.insertOne({ "StudentDetails": [{
"StudentName": "John", "StudentMessage": "Hi"}, {"StudentName": "Larry", "StudentMessage": "Hello"}]})
{
"acknowledged" : true,
"insertedId" : ObjectId("5c92635d36de59bd9de06381")
}
> db.objectInAnArrayDemo.insertOne({ "StudentDetails": [{
"StudentName": "Carol", "StudentMessage": "Hello"}, {"StudentName": "David", "StudentMessage": "Good Morning"}]})
{
"acknowledged" : true,
"insertedId" : ObjectId("5c92637936de59bd9de06382")
}在find()方法的帮助下显示集合中的所有文档。查询如下-
> db.objectInAnArrayDemo.find().pretty();
以下是输出-
{
"_id" : ObjectId("5c92635d36de59bd9de06381"),
"StudentDetails" : [
{
"StudentName" : "John",
"StudentMessage" : "Hi"
},
{
"StudentName" : "Larry",
"StudentMessage" : "Hello"
}
]
}
{
"_id" : ObjectId("5c92637936de59bd9de06382"),
"StudentDetails" : [
{
"StudentName" : "Carol",
"StudentMessage" : "Hello"
},
{
"StudentName" : "David",
"StudentMessage" : "Good Morning"
}
]
}这是使用MongoDB查询数组对象中字段的信息-
> db.objectInAnArrayDemo.find({"StudentDetails": { $elemMatch: { "StudentMessage": "Good Morning" } } } ).pretty();以下是输出-
{
"_id" : ObjectId("5c92637936de59bd9de06382"),
"StudentDetails" : [
{
"StudentName" : "Carol",
"StudentMessage" : "Hello"
},
{
"StudentName" : "David",
"StudentMessage" : "Good Morning"
}
]
}热门推荐
10 八一幼儿祝福语大全简短
11 公司乔迁食堂祝福语简短
12 婚礼结束聚餐祝福语简短
13 儿媳买车妈妈祝福语简短
14 毕业送礼老师祝福语简短
15 同事辞职正常祝福语简短
16 恭贺新婚文案祝福语简短
17 金店立秋祝福语简短英文
18 婆婆高寿祝福语大全简短