>백엔드 개발 >Golang >Go에서 sql.NullString JSON 출력을 평면화하는 방법은 무엇입니까?

Go에서 sql.NullString JSON 출력을 평면화하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-03 00:19:121065검색

How to Flatten sql.NullString JSON Output in Go?

평면화된 sql.NullString 출력을 위한 사용자 정의 마샬링

json.Marshal을 사용하여 Go 구조체에서 sql.NullString 필드를 마샬링할 때 기본값 출력에는 유효 및 문자열 필드와 같은 추가 메타데이터가 포함됩니다. 평면화된 값을 선호하는 특정 시나리오에서는 이 동작이 바람직하지 않을 수 있습니다.

다음 구조체를 고려하세요.

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

이 구조체를 마샬링할 때 결과는 다음과 유사합니다.

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

그러나 원하는 결과는 값:

{
    "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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.