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