首頁 > 後端開發 > Golang > 如何使用 Go 類型轉換處理 JSON 中的 SQL NULL 值?

如何使用 Go 類型轉換處理 JSON 中的 SQL NULL 值?

Susan Sarandon
發布: 2024-12-22 01:31:18
原創
312 人瀏覽過

How to Handle SQL NULL Values in JSON using Go Type Conversions?

使用Go 類型轉換對SQL NULL 值進行JSON 處理

雖然Int64 和String 等Go 類型無法儲存null 值,但可以使用sql.NullInt64 sql.NullString 允許此功能。然而,與常規 Int64 和 String 類型相比,使用 json 套件將這些類型編碼為 JSON 會導致格式變更。

出現這種差異是因為 sql.Null* 類型本身就是結構體,導致JSON 表示中的附加巢狀層級。為了克服這個問題,可以實現遵循 json.Marshaller 和 json.Unmarshaler 介面的自訂類型。

例如,可以定義 JsonNullInt64 類型,嵌入 sql.NullInt64 類型並實現自訂 JSON 處理:

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 {
    // Pointer unmarshalling ensures NULL detection
    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
}
登入後複製

用 sql.NullInt64 取代JsonNullInt64 產生所需的 JSON 編碼。如需進一步測試,請參閱此遊樂場:http://play.golang.org/p/zFESxLcd-c

以上是如何使用 Go 類型轉換處理 JSON 中的 SQL NULL 值?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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