MongoDB
 sql >> Base de données >  >> NoSQL >> MongoDB

Est-il possible de retourner un champ calculé à partir d'une requête MongoDB ?

Le nouveau Cadre d'agrégation dans MongoDB 2.2 vous permet d'ajouter des champs calculés via le $project opérateur. Ce n'est pas tout à fait la même chose que arbitraire fonctionne car vous devez utiliser les opérateurs pris en charge , mais cela offre une bonne dose de flexibilité.

Voici votre exemple d'incrémentation de _id s dans un nouveau myNum champ :

MongoDB shell version: 2.2.0-rc0

> db.test.insert({_id:123});

> db.test.insert({_id:456});

> db.test.aggregate(
  { $project : {
      _id : 1,
     'myNum': { $add: [ "$_id", 1]}
  }}
)
{
    "result" : [
        {
            "_id" : 123,
            "myNum" : 124
        },
        {
            "_id" : 456,
            "myNum" : 457
        }
    ],
    "ok" : 1
}