Rumah > pembangunan bahagian belakang > Golang > Bagaimana untuk Mengendalikan Nilai NULL SQL dalam Go JSON Marshalling?

Bagaimana untuk Mengendalikan Nilai NULL SQL dalam Go JSON Marshalling?

Mary-Kate Olsen
Lepaskan: 2025-01-03 01:47:43
asal
967 orang telah melayarinya

How to Handle SQL NULL Values in Go JSON Marshalling?

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
}
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan