登录
首页 >  Golang >  Go问答

在MongoDB Golang驱动中使用$facet查询

来源:stackoverflow

时间:2024-03-19 15:33:19 468浏览 收藏

MongoDB Golang 驱动中使用 $facet 查询 $facet 查询是一种聚合管道操作,允许对集合中的文档执行多项分组和聚合操作。它在 MongoDB Golang 驱动中可用,可以通过在管道中包含一个 `$facet` 阶段来使用。该阶段接受一个文档作为参数,其中键是输出文档的名称,值是应用于输入文档的管道。

问题内容

  1. 如何使用 mongo golang 驱动程序将以下查询转换为管道
db.transFront.aggregate([
{
        $facet: {
            query1: [ { $match: { appName:"app-38" }}, { $count: "count" }],
            query2: [ { $match: { appName:"app-43" }}, { $count: "count" } ],
            query3: [ { $match: { appName:"app--1" }}, { $count: "count" } ],
        }
    }
])

解决方案


要在 go lang mongodb 驱动程序中运行$facet,请使用以下代码,只需替换您的连接字符串和数据库名称

package main

import (
    "context"
    "time"
    "fmt"
    "go.mongodb.org/mongo-driver/bson"
    "go.mongodb.org/mongo-driver/mongo"
    "go.mongodb.org/mongo-driver/mongo/options"
)

func main() {
    ctx, _ := context.WithTimeout(context.Background(), 10*time.Second)
    client, err := mongo.Connect(ctx, options.Client().ApplyURI("mongodb_connect_string"))
    if err != nil {
        panic(err)
    }
    defer client.Disconnect(ctx)

    database := client.Database("testdb")
    transFront := database.Collection("transFront")



    query1 := bson.A{bson.D{{"$match", bson.D{{"appName", "app-38"}}}}, bson.D{{"$count", "count"}}}
    query2 := bson.A{bson.D{{"$match", bson.D{{"appName", "app-43"}}}}, bson.D{{"$count", "count"}}}
    query3 := bson.A{bson.D{{"$match", bson.D{{"appName", "app--1"}}}}, bson.D{{"$count", "count"}}}

    facetStage := bson.D{{"$facet", bson.D{{"query1", query1}, {"query2", query2}, {"query3", query3}}}}

    showInfoCursor, err := transFront.Aggregate(ctx, mongo.Pipeline{facetStage})
    if err != nil {
            panic(err)
    }
    var showsWithInfo []bson.M
    if err = showInfoCursor.All(ctx, &showsWithInfo); err != nil {
            panic(err)
    }

    fmt.Println(showsWithInfo)
}

以上就是《在MongoDB Golang驱动中使用$facet查询》的详细内容,更多关于的资料请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>