sql >> Databáze >  >> NoSQL >> MongoDB

Vrátí pouze hodnotu pole v mongo projekci

JSON neumožňuje, aby byla nejvyšší úroveň pole, takže běžný dotaz to neumožňuje. Můžete to však provést pomocí agregačního rámce:

> db.test.remove();
> db.test.insert({ name: "Andrew", attributes: [ { title: "Happy"}, { title: "Sad" } ] });
> foo = db.test.aggregate( { $match: { name: "Andrew" } }, { $unwind: "$attributes" }, { $project: { _id: 0, title: "$attributes.title" } } );
{
    "result" : [
        {
            "title" : "Happy"
        },
        {
            "title" : "Sad"
        }
    ],
    "ok" : 1
}
> foo.result
[ { "title" : "Happy" }, { "title" : "Sad" } ]

To však nevytvoří objekt kurzoru, který jej najde.




  1. Mongodb vyhledávací pole prvků s kombinovaným výsledkem

  2. Agregace MongoDB - $skupina podle data, i když neexistuje

  3. Mongo odstranit poslední dokumenty

  4. MongoDB Java:Hledání objektů v Mongo pomocí operátoru QueryBuilder $in nevrací nic