登录
首页 >  Golang >  Go问答

使用Go中的bson.M查询MongoDB数据

来源:stackoverflow

时间:2024-03-09 22:27:25 497浏览 收藏

编程并不是一个机械性的工作,而是需要有思考,有创新的工作,语法是固定的,但解决问题的思路则是依靠人的思维,这就需要我们坚持学习和更新自己的知识。今天golang学习网就整理分享《使用Go中的bson.M查询MongoDB数据》,文章讲解的知识点主要包括,如果你对Golang方面的知识点感兴趣,就不要错过golang学习网,在这可以对大家的知识积累有所帮助,助力开发能力的提升。

问题内容

我使用 mongodb 作为数据库。我可以使用命令从命令行查询数据库

db.nfinstances.distinct("ipv4addresses",{"nftype":"amf", "amfinfo.amfsetid": "3fa85f64-5717-4562-b3fc-2c963f66af33"})

这给了我我想要的 ip 地址 [x.x.x.x] 输出。

但是,如果我使用 golang 查询进行查询

var sliceip []nfinstance

db.c(collection).find(bson.m{
                      "nftype": "amf",
                      "amfinfo.amfsetid": "3fa85f64-5717-4562-b3fc-2c963f66af33"}
                      ).distinct("ipv4addresses", &sliceip)

我得到一个空数组,而不是数组中的 ip 地址字符串。在数据库中,我的 json 文档为

{
    "nfinstanceid": "3fa85f64-5717-4562-b3fc-2c963f66af33",
    "nftype": [
        "amf"
    ],
    "nfstatus": [
        "registered"
    ],
    "snssais": [
        {
            "sst": 1,
            "sd": "sd1"
        }
    ],
    "nsilist": [
        "string"
    ],
    "ipv4addresses": [
        "198.51.100.300"
    ],
    "allowednssais": [
        {
            "sst": 1,
            "sd": "sd1"
        }
    ],
    "amfinfo": {
        "amfsetid": "3fa85f64-5717-4562-b3fc-2c963f66af33",
        "tailist": [
            {
                "plmnid": {
                    "mcc": "244",
                    "mnc": "38"
                },
                "tac": "string"
            }
        ],
        "n2interfaceamfinfo": {
            "ipv4endpointaddress": [
                "198.51.100.105"
            ]
        }
    }
}

mongodb 命令行查询如下所示

> db.nfinstances.distinct("ipv4Addresses",{"nfType":"AMF", "amfInfo.amfSetId": "3fa85f64-5717-4562-b3fc-2c963f66af33"})

mongodb Output:

[ "198.51.100.300" ]

我期望使用 bson.m 得到相同的输出

谁能帮忙找出问题所在吗?


解决方案


Query.Distinct() 解组不同的列表,而不是完整的文档(等效的 mongodb 查询也返回值,而不是文档)。

因此,只需将不同的 ip 解组为 []string 类型的值(并且永远不要忘记处理错误):

var ips []string

err := db.C(COLLECTION).Find(bson.M{
    "nfType":           "AMF",
    "amfInfo.amfSetId": "3fa85f64-5717-4562-b3fc-2c963f66af33",
}).Distinct("ipv4Addresses", &ips)
if err != nil {
    // handle error
}

今天带大家了解了的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

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