> 백엔드 개발 > Golang > Go에서 SQL NULL 값과 JSON을 효과적으로 처리하는 방법은 무엇입니까?

Go에서 SQL NULL 값과 JSON을 효과적으로 처리하는 방법은 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2024-12-21 07:16:17
원래의
639명이 탐색했습니다.

How to Handle SQL NULL Values and JSON Effectively in Go?

Go에서 SQL NULL 값 및 JSON 작업

Go에서 null 허용 값으로 작업할 때는 sql.NullInt64와 같은 유형을 사용하는 것이 일반적입니다. 및 sql.NullString. 그러나 이러한 유형은 이를 포함하는 구조체에서 JSON을 생성할 때 예기치 않은 결과를 초래할 수 있습니다. 특히 sql.Null***도 구조체이기 때문에 JSON 출력에 추가 수준이 포함될 수 있습니다.

해결 방법

이 문제를 해결하려면 다음을 수행하세요. json.Marshaller 및 json.Unmarshaler 인터페이스를 구현하는 사용자 정의 유형을 만듭니다. sql.NullInt64 유형을 포함하면 고유한 JSON 마샬링 및 역마샬링 동작을 정의하면서 SQL 메서드를 원활하게 처리할 수 있습니다.

예는 다음과 같습니다.

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 {
    // Unmarshalling into a pointer will let us detect null
    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
}
로그인 후 복사

대신 이 사용자 정의 유형을 사용하는 경우 sql.NullInt64를 사용하면 JSON 출력은 추가 항목 없이 예상한 형식이 됩니다. level.

다음 링크에서 이 예를 테스트할 수 있습니다:

http://play.golang.org/p/zFESxLcd -c

위 내용은 Go에서 SQL NULL 값과 JSON을 효과적으로 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿