登录
首页 >  Golang >  Go问答

奇怪解码JSON数组的Go-MongoDriver

来源:stackoverflow

时间:2024-02-26 17:27:23 172浏览 收藏

Golang小白一枚,正在不断学习积累知识,现将学习到的知识记录一下,也是将我的所得分享给大家!而今天这篇文章《奇怪解码JSON数组的Go-MongoDriver》带大家来了解一下##content_title##,希望对大家的知识积累有所帮助,从而弥补自己的不足,助力实战开发!


问题内容

heyho 派对人士,

我最近开始学习 go,并开始从事一个小型副项目,其中包括使用 go fiber 库编写的 api。 所有必要的数据都存储在 mongodb 中,架构如下

{
    "objectid": {
        "name": "name",
        "url": "url",
        "dateadded": "date",
        "data": [{
                "timestamp 1": "price 1"
            },
            {
                "timestamp 2": "price 2"
            }
        ]
    }
}

项目类型如下所示:

type item struct {
    id        primitive.objectid `json:"_id" bson:"_id"`
    name      string             `json:"name" bson:"name"`
    url       string             `json:"url" bson:"url"`
    dateadded string             `json:"dateadded" bson:"dateadded"`
    data      []interface{}      `json:"data" bson:"data"`
}

每当我查询存储的项目时

err = collection.findone(context.todo(), filter).decode(&item)

数据数组内的每个地图都包装在另一个数组中=>

{ test url 2021-04-16 [[{2021-04-16 99.99}] [{2021-04-17 109.99}]] }

instead of

{ test url 2021-04-16 [{2021-04-16 99.99}, {2021-04-17 109.99}] }

有人知道如何解决这个问题吗? 预先感谢!


正确答案


好的,我已经找到了一种方法来修复我的用例的此行为。

如上所述,go 的 mongodb 驱动程序将数组的每个条目包装到另一个相应的数组中,从而形成一个嵌套数组。

经过一段时间的尝试后,我发现将文档插入到您的集合中,如下例所示,

db.collection.insertone({ name: "name", url: "url", dateadded: "2021-04-25", data: { "2021-04-25": 9.99, "2021-04-26": 19.99 } })

那么在您的程序中执行查询的结果如下所示:

{ objectid("60858245f8805dc57a716500") name url 2021-04-25 [{ 2021-04-25 9.99 } { 2021-04-26 19.99 }] }

这意味着 json 模式应该如下所示

{
    "objectid": {
        "name": "name",
        "url": "url",
        "dateadded": "date",
        "data": {
            "2021-04-25": 9.99,
            "2021-04-26": 19.99
        }
    }
}

遗憾的是,我无法找出到底是什么导致了这种奇怪的行为,但我希望这可以帮助任何遇到此(或类似)问题的人。

编辑

data 字段的类型更改为 []bson.m,如下面评论中的 mkopriva 所说,修复了它。

type item struct {
    id        primitive.objectid `json:"_id" bson:"_id"`
    name      string             `json:"name" bson:"name"`
    url       string             `json:"url" bson:"url"`
    dateadded string             `json:"dateadded" bson:"dateadded"`
    data      []bson.m           `json:"data" bson:"data"`
}

这样,原始 json 模式就不必适应解决方法。

{
    "ObjectId":{
        "name":"name",
        "url":"url",
        "dateAdded":"date",
        "data": [
            {
                "2021-04-25": 9.99
            },
            {
                "2021-04-26": 19.99
            }
        ]
    }
}

到这里,我们也就讲完了《奇怪解码JSON数组的Go-MongoDriver》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

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