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

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

Patricia Arquette
發布: 2024-12-03 00:19:12
原創
1074 人瀏覽過

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中文網其他相關文章!

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