首頁 >後端開發 >Golang >如何在 Go 中展平 sql.NullString JSON 輸出?

如何在 Go 中展平 sql.NullString JSON 輸出?

Patricia Arquette
Patricia Arquette原創
2024-12-03 00:19:121091瀏覽

How to Flatten sql.NullString JSON Output in Go?

扁平化sql.NullString 輸出的自訂封送

使用json.Marshal 在Go 結構中封送時,預設值輸出包括其他元數據,例如有效欄位和字串欄位。在某些首選扁平化值的場景中,可能不需要這種行為。

考慮以下結構:

type Company struct {
    ID   int             `json:"id"`              
    Abn  sql.NullString  `json:"abn,string"`
}

編組此結構時,結果將類似於以下內容:

{
    "id": "68",
    "abn": {
        "String": "SomeABN",
        "Valid": true
    }
}

然而,期望的結果是一個扁平化版本,其中只有value:

{
    "id": "68",
    "abn": "SomeABN"
}

自訂Marshaller實作

要實現此目的,需要實作一個嵌入 sql.NullString 並實作 json.Marshaler 介面的自訂類型。此自訂類型可以透過 MarshalJSON 方法定義自己的編組行為。

這是一個範例:

type MyNullString struct {
    sql.NullString
}

func (s MyNullString) MarshalJSON() ([]byte, error) {
    if s.Valid {
        return json.Marshal(s.String)
    }
    return []byte(`null`), nil
}

type Company struct {
    ID   int          `json:"id"`              
    Abn  MyNullString `json:"abn,string"`
}

透過使用自訂 MyNullString 類型,編組現在將產生所需的扁平化結果:

company := &Company{}
company.ID = 68
company.Abn.String = "SomeABN"
result, err := json.Marshal(company)
{
    "id": "68",
    "abn": "SomeABN"
}

以上是如何在 Go 中展平 sql.NullString JSON 輸出?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn