Go-MongoDriver 奇怪地解码 JSON 数组
Go-MongoDriver decoding JSON array weirdly
嘿嘿党人,
我最近开始学习 Go 并开始从事一个小型的副项目,其中包括一个 API 使用 Go Fiber 库编写的项目。
所有必需的数据都存储在 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-driver 将数组的每个条目包装到另一个相应的数组中,从而导致嵌套数组。
尝试了一段时间后,我发现,将文档插入您的 collection 就像下面的例子,
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-schema 应该看起来像这样
{
"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-schema就不用去适应workaround了。
{
"ObjectId":{
"name":"name",
"url":"url",
"dateAdded":"date",
"data": [
{
"2021-04-25": 9.99
},
{
"2021-04-26": 19.99
}
]
}
}
嘿嘿党人,
我最近开始学习 Go 并开始从事一个小型的副项目,其中包括一个 API 使用 Go Fiber 库编写的项目。 所有必需的数据都存储在 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-driver 将数组的每个条目包装到另一个相应的数组中,从而导致嵌套数组。
尝试了一段时间后,我发现,将文档插入您的 collection 就像下面的例子,
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-schema 应该看起来像这样
{
"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-schema就不用去适应workaround了。
{
"ObjectId":{
"name":"name",
"url":"url",
"dateAdded":"date",
"data": [
{
"2021-04-25": 9.99
},
{
"2021-04-26": 19.99
}
]
}
}