sql >> Databáze >  >> NoSQL >> MongoDB

mongo agregační dotaz s ovladačem mgo

Pro začátek by stačily příklady v dokumentech. Pokud však neznáte golang, $cond část by mohla být trochu složitější. Viz níže příklad kódu:

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

Viz také mgo:type Pipe




  1. mongolastic indexování kolekce trvá dlouho

  2. Řešení UnhandledPromiseRejectionWarning v žádosti o expresní poštu

  3. Jak se dotazovat pouze na dokumenty s nejnovějším časovým razítkem ze skupiny?

  4. Má Pymongo zabudovaná ověřovací pravidla?