Rumah >pembangunan bahagian belakang >Golang >Bagaimana untuk Meratakan Output JSON sql.NullString dalam Go?

Bagaimana untuk Meratakan Output JSON sql.NullString dalam Go?

Patricia Arquette
Patricia Arquetteasal
2024-12-03 00:19:12987semak imbas

How to Flatten sql.NullString JSON Output in Go?

Custom Marshaling for Flattened sql.NullString Output

Apabila menyusun medan sql.NullString dalam struct Go menggunakan json.Marshal, lalai output termasuk metadata tambahan seperti medan Sah dan String. Tingkah laku ini mungkin tidak diingini dalam senario tertentu di mana nilai yang diratakan lebih diutamakan.

Pertimbangkan struct berikut:

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

Apabila menyusun struct ini, hasilnya akan menyerupai yang berikut:

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

Walau bagaimanapun, hasil yang diingini ialah versi yang diratakan dengan hanya value:

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

Pelaksanaan Marshaller Tersuai

Untuk mencapai ini, adalah perlu untuk melaksanakan jenis tersuai yang membenamkan sql.NullString dan melaksanakan antara muka json.Marshaler . Jenis tersuai ini boleh mentakrifkan gelagat marshallingnya sendiri melalui kaedah MarshalJSON.

Berikut ialah contoh:

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"`
}

Dengan menggunakan jenis MyNullString tersuai, marshalling kini akan menghasilkan hasil rata yang diingini:

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

Atas ialah kandungan terperinci Bagaimana untuk Meratakan Output JSON sql.NullString dalam Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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