Di Golang, apabila menyimpan data ke MongoDB, anda sering menghadapi masalah nilai data nol. Apabila nilai medan kosong, MongoDB menyimpannya sebagai batal secara lalai. Walau bagaimanapun, dalam aplikasi sebenar, kami mungkin lebih suka menyimpannya sebagai nilai lalai khusus untuk pemprosesan dan pertanyaan data yang lebih baik. Jadi, bagaimana untuk menyelesaikan masalah ini di Golang? Artikel ini akan dijawab secara terperinci oleh editor php Baicao.
Saya baru di Golang dan saya menghadapi masalah menyimpan data ke pangkalan data. Selepas menerima objek JSON daripada API, saya cuba menyimpannya dalam MongoDB tetapi data telah disimpan dengan nilai nol.
Ini kod dan struktur saya:
var current:={ "usd": { "code": "USD", "alphaCode": "USD", "numericCode": "840", "name": "U.S. Dollar", "rate": 0.68135437808647, "date": "Sun, 31 Dec 2023 11:55:01 GMT", "inverseRate": 1.4676650391657 }, "eur": { "code": "EUR", "alphaCode": "EUR", "numericCode": "978", "name": "Euro", "rate": 0.61624276207684, "date": "Sun, 31 Dec 2023 11:55:01 GMT", "inverseRate": 1.6227371119619 }, "gbp": { "code": "GBP", "alphaCode": "GBP", "numericCode": "826", "name": "U.K. Pound Sterling", "rate": 0.53541690218052, "date": "Sun, 31 Dec 2023 11:55:01 GMT", "inverseRate": 1.8677034586085 } }
Ini model saya.go
type Currency struct { Code string `json:"code"` AlphaCode string `json:"alphaCode"` NumericCode string `json:"numericCode"` Name string `json:"name"` Rate float64 `json:"rate"` Date string `json:"date"` InverseRate float64 `json:"inverseRate"` } type Rate struct { ID primitive.ObjectID `json:"_id,omitempty" bson:"_id,omitempty"` Currency `json:"currency"` Timestamp primitive.DateTime `json:"timestamp"` }
Saya cuba menyimpan data ke pangkalan data tetapi saya hanya menulis nilai lalai dengan rentetan kosong dan 0
const apiUrl = "https://www.floatrates.com/daily/aud.json" func GetRatesFromAPI() (map[string]models.Rate, error) { response, err := http.Get(apiUrl) fmt.Print(response) if err != nil { return nil, err } defer response.Body.Close() body, err := ioutil.ReadAll(response.Body) if err != nil { return nil, err } var data map[string]models.Rate if err := json.Unmarshal(body, &data); err != nil { return nil, err } fmt.Print(data) return data, nil } r.GET("/get", func(c *gin.Context) { mongo.ConnectDB() rates, err := src.GetRatesFromAPI() fmt.Print(rates) if err != nil { log.Fatal(err) } for _, rate := range rates { mongo.InsertRate(rate) } c.String(http.StatusOK, "get rates") }) func InsertRate(rate models.Rate) { rate.Timestamp = primitive.NewDateTimeFromTime(time.Now()) collection := client.Database("mongodb").Collection("rates") ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second) defer cancel() result, err := collection.InsertOne(ctx, rate) if err != nil { log.Fatal(err) } log.Println("Inserted rate with ID:", result.InsertedID) }
Saya mendapat objek ini dalam pangkalan data tetapi tanpa sebarang nilai dan saya cuba mengetahui mengapa data tidak disimpan dengan betul dalam MongoDB. Sebarang bantuan atau nasihat akan sangat dihargai!
[ { "_id": {"$oid": "659177abefa699e213158c16"}, "currency": { "code": "", "alphacode": "", "numericcode": "", "name": "", "rate": 0, "date": "", "inverserate": 0 }, "timestamp": {"$date": "2023-12-31T14:16:11.800Z"} } ]
Masalahnya disebabkan oleh penggunaan tag json json:"currency"
在 Rate
类型中嵌入 Currency
类型而引起的。但是,为 json.Unmarshal
提供的输入 JSON 不包含相应的“Currency
”字段。因此,Currency
类型中的所有字段都会接收零值,然后将其存储在 MongoDB 中。为了解决这个问题,您可以在嵌入 Currency
类型期间消除 json 标签 json:"currency"
(ditunjukkan di bawah), atau membina objek sasaran agar konsisten dengan struktur input JSON.
type Rate struct { ID primitive.ObjectID `json:"_id,omitempty" bson:"_id,omitempty"` Currency Timestamp primitive.DateTime `json:"timestamp"` }
Atas ialah kandungan terperinci Bagaimana untuk menyelesaikan isu nilai data nol apabila menyimpan ke MongoDB di Golang?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!