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