Rumah >pembangunan bahagian belakang >Golang >Bagaimana untuk menyelesaikan isu nilai data nol apabila menyimpan ke MongoDB di Golang?

Bagaimana untuk menyelesaikan isu nilai data nol apabila menyimpan ke MongoDB di Golang?

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBke hadapan
2024-02-09 09:40:09672semak imbas

在 Golang 中保存到 MongoDB 时如何解决空数据值问题?

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.

Kandungan soalan

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

Penyelesaian

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!

Kenyataan:
Artikel ini dikembalikan pada:stackoverflow.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam
Artikel sebelumnya:golang gin dapatkan biskut jsonArtikel seterusnya:golang gin dapatkan biskut json