簡體   English   中英

Go-MongoDriver 奇怪地解碼 JSON 數組

[英]Go-MongoDriver decoding JSON array weirdly

嘿嘿黨的人,

我最近開始學習 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)

數據陣列內部的每個 map 都包裝在另一個陣列中 =>

{ 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
        }
    }
}

遺憾的是,我無法找出導致這種奇怪行為的真正原因,但我希望這可以幫助遇到這個(或類似)問題的任何人。

編輯

正如mkopriva在下面的評論中所說,將Data -field 的類型更改為[]bson.M ,修復了它。

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
            }
        ]
    }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM