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

Oversættelse af sql-forespørgsel til Mongo-languague

Antag, at du har disse dokumenter i dine events :

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

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

Du kan ikke bruge en simpel find() forespørgsel. Du skal bruge aggregering:

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

resultatet er:

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



  1. Byg en reaktiv publikation med yderligere felter i hvert dokument

  2. Opret _id på underdokumenter på mongoimport --jsonArray

  3. 2 måder at tilføje en værdi til et array i MongoDB

  4. MongoDB-aggregat, hvordan man tilføjerToSet hvert element af array i gruppepipeline