像sql.NullInt64这样的类型不会对JSON编组或解组进行任何特殊处理,所以默认规则适用.因为类型是一个结构体,所以它被编组为一个对象,其字段是属性.
解决这个问题的一个方法是创建自己的类型来实现json.Marshaller / json.Unmarshaler接口.通过嵌入sql.NullInt64类型,我们可以免费获得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,则应按预期编码.