在 Golang 中保存到 MongoDB 时如何解决空数据值问题?
在Golang中,保存数据到MongoDB时,经常会遇到空数据值的问题。当某个字段的值为空时,MongoDB默认会将其存储为null。然而,在实际应用中,我们可能更希望将其存储为一个特定的默认值,以便更好地处理和查询数据。那么,在Golang中如何解决这个问题呢?本文将由php小编百草为您详细解答。
问题内容
我是 Golang 的新手,我遇到了将数据保存到数据库的问题。从 API 接收到 JSON 对象后,我尝试将其存储在 MongoDB 中,但数据以空值保存。
这是我的代码和结构:
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
}
}
这是我的 model.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"`
}
我尝试将数据保存到数据库,但我只写入带有空字符串和 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 := class="lazy" data-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)
}
我在数据库中得到这个对象,但没有任何值,我试图找出为什么数据没有正确存储在 MongoDB 中。任何帮助或建议将不胜感激!
[
{
"_id": {"$oid": "659177abefa699e213158c16"},
"currency": {
"code": "",
"alphacode": "",
"numericcode": "",
"name": "",
"rate": 0,
"date": "",
"inverserate": 0
},
"timestamp": {"$date": "2023-12-31T14:16:11.800Z"}
}
]
解决方法
问题是由于使用 json 标签 json:"currency"
在 Rate
类型中嵌入 Currency
类型而引起的。但是,为 json.Unmarshal
提供的输入 JSON 不包含相应的“Currency
”字段。因此,Currency
类型中的所有字段都会接收零值,然后将其存储在 MongoDB 中。为了解决这个问题,您可以在嵌入 Currency
类型期间消除 json 标签 json:"currency"
(如下所示),或者构建目标对象以与输入 JSON 的结构保持一致。
type Rate struct {
ID primitive.ObjectID `json:"_id,omitempty" bson:"_id,omitempty"`
Currency
Timestamp primitive.DateTime `json:"timestamp"`
}
以上就是在 Golang 中保存到 MongoDB 时如何解决空数据值问题?的详细内容,更多请关注编程网其它相关文章!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341