sql >> Databasteknik >  >> NoSQL >> MongoDB

Översättning av sql-fråga till Mongo språk

Anta att du har dessa dokument i dina events :

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

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

Du kan inte använda en enkel find() fråga. Du bör använda aggregering:

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

resultatet är:

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



  1. Kan jag använda MongoDB som ersättning för CoreData på iOS?

  2. MongoDB &CodeIgniter:Välj var ett fält finns

  3. Mongodb:sortera dokument efter arrayobjekt

  4. MongoDB- Infoga om det inte finns, annars hoppa över