sql >> Base de Datos >  >> NoSQL >> MongoDB

¿Es posible devolver un campo calculado de una consulta MongoDB?

El nuevo marco de agregación en MongoDB 2.2 le permite agregar campos calculados a través del $project operador. Esto no es lo mismo que arbitrario funciones porque necesita usar operadores admitidos , pero proporciona mucha flexibilidad.

Aquí está su ejemplo de incrementar _id s en un nuevo myNum campo:

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
}