像int64这样的值,字符串不能存储空值.所以我发现我们
可以使用sql.NullInt64和sql.NullString.
可以使用sql.NullInt64和sql.NullString.
但是当我在一个结构体中使用这些结构,并从结构体中使用JSON包生成JSON时,格式不是当我使用常规int64和字符串时的方式.我的意思是它有一个额外的级别,因为sql.Null ***也是一个结构体.
解决方法
像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,则应按预期编码.
你可以在这里测试这个例子:http://play.golang.org/p/zFESxLcd-c