加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

如何处理高阶的sql NULL值和JSON?

发布时间:2020-12-12 08:33:56 所属栏目:MsSql教程 来源:网络整理
导读:像int64这样的值,字符串不能存储空值.所以我发现我们 可以使用sql.NullInt64和sql.NullString. 但是当我在一个结构体中使用这些结构,并从结构体中使用JSON包生成JSON时,格式不是当我使用常规int64和字符串时的方式.我的意思是它有一个额外的级别,因为sql.Null
像int64这样的值,字符串不能存储空值.所以我发现我们
可以使用sql.NullInt64和sql.NullString.

但是当我在一个结构体中使用这些结构,并从结构体中使用JSON包生成JSON时,格式不是当我使用常规int64和字符串时的方式.我的意思是它有一个额外的级别,因为sql.Null ***也是一个结构体.

有没有一个很好的解决方法,或者我不应该在我的MySQL数据库中使用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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读