sql >> Database >  >> NoSQL >> MongoDB

Vertaling van sql-query naar Mongo languague

Stel dat je deze documenten in je events hebt staan :

{
    "_id" : ObjectId("54cdfde528bb923955eff8b4"),
    "v1" : 35,
    "v2" : 10
}

/* 1 */
{
    "_id" : ObjectId("54cdfde928bb923955eff8b5"),
    "v1" : 10,
    "v2" : 20
}

Je kunt geen simpele find() gebruiken vraag. U moet aggregatie gebruiken:

db.events.aggregate(
[    
    { $project : { 'diff' : { $subtract : ['$v1', '$v2'] }, v1 : 1, v2 : 1 } },
    { $match : { diff : { $gt : 20} } },
    { $project : { v1 : 1, v2 : 1 } },
]).result

het resultaat is:

{
    "0" : {
        "_id" : ObjectId("54cdfde528bb923955eff8b4"),
        "v1" : 35,
        "v2" : 10
    }
}



  1. Het volgende document vinden in MongoDb

  2. Mongoose ODM:NumberInt is niet gedefinieerd

  3. MongoDB ReplicaSet - PRIMARY-rol valt op SECUNDAIRE wanneer alleen PRIMARY over is

  4. Mongoose / MongoDB:tel elementen in array