我想使用MongoDB java api从mongodb文件中的数组中获取特定的数组元素记录

时间:2015-01-05 14:47:55

标签: java arrays mongodb mongodb-query

我有一个包含多个数组元素的文档。 我想从数组中找到一些特定的值。

{
    "_id" : ObjectId("54a67aa569f2bc6a5865f220"),       
    "language" : "us_english",
    "country" : "united states",
    "state" : "texas",
    "words" : [ 
        {

            "handle" : "gm",
            "replacement" : "good morning",

        }, 
        {

            "handle" : "ilu",
            "replacement" : "i love you",

        }
    ]
}

我希望在replacementhandle is gmlanguage is englishcountry is united states找到state is texas的值。

我尝试了很多解决方案,但我无法从文档中找到具体的价值。

有没有解决方案?

1 个答案:

答案 0 :(得分:1)

您可以使用聚合操作。

  • $match来过滤文档
  • $unwind解构words字段
  • 重复使用$match查找replacement字段

    的值
    db.collection.aggregate([{$match : {language : 'us_english', country: 'united states', state: 'texas'}}, {$unwind: '$words'}, {$match: {"words.handle" : "gm"}}])
    
    { "_id" : ObjectId("54a67aa569f2bc6a5865f220"), "language" : "us_english", "country" : "united states", "state" : "texas", "words" : { "handle" : "gm", "replacement" : "good morning" } }