首頁 > 後端開發 > Golang > 如何在 Go JSON 編組中處理 SQL NULL 值?

如何在 Go JSON 編組中處理 SQL NULL 值?

Mary-Kate Olsen
發布: 2025-01-03 01:47:43
原創
969 人瀏覽過

How to Handle SQL NULL Values in Go JSON Marshalling?

Go 中SQL NULL 值的JSON 處理

在Go 中處理可空SQL 資料類型時,經常使用sql.Nullxxx 類型允許空值。但是,在使用 json 套件將此類結構編碼為 JSON 時,這可能會導致格式問題。

預設情況下,sql.Nullxxx 類型因其結構性質而被封送為具有附加層級的物件。這可能會導致不必要的 JSON 輸出。若要解決此問題,請考慮為嵌入 sql.Nullxxx 類型的自訂類型實作 json.Marshaller 和 json.Unmarshaler 介面。

例如,以下JsonNullInt64 類型可用於將sql.NullInt64 值編碼為null 或整數:

type JsonNullInt64 struct {
    sql.NullInt64
}

func (v JsonNullInt64) MarshalJSON() ([]byte, error) {
    if v.Valid {
        return json.Marshal(v.Int64)
    } else {
        return json.Marshal(nil)
    }
}

func (v *JsonNullInt64) UnmarshalJSON(data []byte) error {
    var x *int64
    if err := json.Unmarshal(data, &x); err != nil {
        return err
    }
    if x != nil {
        v.Valid = true
        v.Int64 = *x
    } else {
        v.Valid = false
    }
    return nil
}
登入後複製

使用JsonNullInt64 時類型,它將以預期的方式進行編碼,允許正確的JSON 表示,而無需額外的等級。

以上是如何在 Go JSON 編組中處理 SQL NULL 值?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板