MongoDB
 sql >> Database >  >> NoSQL >> MongoDB

È possibile restituire un campo calcolato da una query MongoDB?

Il nuovo Quadro di aggregazione in MongoDB 2.2 consente di aggiungere campi calcolati tramite $project operatore. Non è proprio la stessa cosa di arbitrario funzioni perché è necessario utilizzare operatori supportati , ma fornisce una buona dose di flessibilità.

Ecco il tuo esempio di incremento di _id s in un nuovo 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
}