sql >> Databasteknik >  >> NoSQL >> MongoDB

mongo aggregeringsfråga med mgo-drivrutinen

Exemplen på dokumenten skulle vara tillräckliga för att komma igång. Men om du inte är bekant med golang, $cond del kan vara lite knepigt. Se nedan exempelkod:

    collection := session.DB("dbName").C("devices")

    stage_match := bson.M{"$match":bson.M{"userId":"v73TuQqZykbxFXsWo", "state": true}}

    condition_weight := []interface{}{bson.M{"$or": []bson.M{
                       bson.M{"$eq": []string{"$categorySlug", "air_fryer"}},
                       bson.M{"$eq": []string{"$categorySlug", "iron"}},
    }}, 0, 1}

    stage_project:= bson.M{"$project": bson.M{"userId":1, "categorySlug":1, "weight": condition_weight}}

    stage_sort := bson.M{"$sort": bson.M{"weight":1}}

    stage_limit := bson.M{"$limit": 10}

    pipe := collection.Pipe([]bson.M{stage_match, stage_project, stage_sort, stage_limit})

Se även mgo:typ Pipe




  1. Ansluter till Redis som körs i Docker Container från värddator

  2. Kör javascript-skript (.js-fil) i mongodb inklusive en annan fil inuti js

  3. Det går inte att skicka data till MongoDB med Kafka-Spark Structured Streaming

  4. Hur man kontrollerar kopplingen mellan mysql och memcached i php