sql >> Database >  >> NoSQL >> MongoDB

mongo-aggregatiequery met mgo-stuurprogramma

De voorbeelden in de documenten zouden voldoende zijn om aan de slag te gaan. Als u echter niet bekend bent met golang, de $cond deel kan een beetje lastig zijn. Zie onderstaande voorbeeldcode:

    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})

Zie ook mgo:type Pipe




  1. Redis, hoe verhoog je alle scores van een zset met ZINCRBY?

  2. hoe mongoDB-object-id in java te maken

  3. gooi nieuwe mangoest.Error.MissingSchemaError(naam); ^ MongooseError:Schema is niet geregistreerd voor modelhandelaar

  4. Welke aggregatiecursormethoden worden ondersteund door Nodejs-stuurprogramma's?