JSON Pengendalian Nilai NULL SQL dalam Go
Apabila bekerja dengan jenis data SQL boleh null dalam Go, jenis sql.Nullxxx sering digunakan untuk membenarkan nilai nol. Walau bagaimanapun, ini boleh membawa kepada isu pemformatan apabila mengekodkan struktur tersebut ke dalam JSON menggunakan pakej json.
Secara lalai, jenis sql.Nullxxx disusun sebagai objek dengan tahap tambahan kerana sifat strukturnya. Ini boleh mengakibatkan output JSON yang tidak diingini. Untuk menangani perkara ini, pertimbangkan untuk melaksanakan antara muka json.Marshaller dan json.Unmarshaler untuk jenis tersuai yang membenamkan jenis sql.Nullxxx.
Sebagai contoh, jenis JsonNullInt64 berikut boleh digunakan untuk pengekodan nilai sql.NullInt64 sebagai nol atau integer:
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 }
Apabila menggunakan Jenis JsonNullInt64, ia akan dikodkan mengikut cara yang dijangkakan, membenarkan perwakilan JSON yang betul tanpa tahap tambahan.
Atas ialah kandungan terperinci Bagaimana untuk Mengendalikan Nilai NULL SQL dalam Go JSON Marshalling?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!