第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

如何使用 mongo-driver 在 Go 中執(zhí)行聚合

如何使用 mongo-driver 在 Go 中執(zhí)行聚合

Go
阿波羅的戰(zhàn)車 2022-04-26 15:54:40
我有一個(gè)包含 3 個(gè)字段的 MongoDB 集合:_id: ObjectIdfield1: Numberfield2: Number我正在執(zhí)行此聚合以獲取“不同”的 field1/field2 行并對結(jié)果進(jìn)行總計(jì)數(shù)。這在客戶端(Robo3t)中可以正常工作:db.mycollection.aggregate([    {        $group: {             _id: { field1: "$field1", field2: "$field2" },        }    },    {         $group: {             _id: null, count: { $sum: 1 }         }     }])結(jié)果:{    "_id" : null,    "count" : 57.0}我如何使用mongo-driver在 Go 中進(jìn)行這種聚合?有這種方法可以執(zhí)行聚合,但我不清楚文檔。我知道我應(yīng)該做某種 bson 查詢,但我不知道從哪里開始。
查看完整描述

2 回答

?
郎朗坤

TA貢獻(xiàn)1921條經(jīng)驗(yàn) 獲得超9個(gè)贊

group :=[]bson.M{bson.M{

    "$group": bson.M{

        "_id":bson.M{

            "field1": "$field1",

            "field2": "$field2"

        }

    }

},

bson.M {

    "$group": bson.M{

        "_id":nil,

        "count": bson.M{

            "$sum":1

        }

    }

}


cursor, err := coll.Aggregate(context.Background(), mongo.Pipeline{group})

if err != nil {

    log.Fatal(err)

}

嘗試上述解決方案,它會(huì)工作。


查看完整回答
反對 回復(fù) 2022-04-26
?
呼啦一陣風(fēng)

TA貢獻(xiàn)1802條經(jīng)驗(yàn) 獲得超6個(gè)贊

為了補(bǔ)充公認(rèn)的解決方案,我將與光標(biāo)迭代和解碼共享完整代碼。我將其更改"_id": nil為"_id": ""接收字符串并能夠毫無問題地解碼為結(jié)構(gòu)。


pipeline := []bson.M{

    {

        "$group": bson.M{"_id": bson.M{"field1": "$field1", "field2": "$field2"}},

    },

    {

        "$group": bson.M{"_id": "", "count": bson.M{"$sum": 1}},

    },

}


cursor, err := coll.Aggregate(ctx, pipeline)

if err != nil {

    return err

}

type Result struct {

    ID    string `bson:"_id"`

    Count int    `bson:"count"`

}

var res Result

for cursor.Next(ctx) {

    err := cursor.Decode(&res)

    if err != nil {

        return err

    }

    fmt.Printf("Element %v", res)

}


查看完整回答
反對 回復(fù) 2022-04-26
  • 2 回答
  • 0 關(guān)注
  • 213 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)