ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

Go 数据库存储数组、json类型

2021-12-27 14:32:55  阅读:146  来源: 互联网

标签:return nil err 数据库 bytes Value json error Go


本文主要介绍用数据库varchar字段存储序列化数据。
通过实现 database/sql/driver 的接口,实现Value() (driver.Value, error)Scan(interface{}) error函数。

一、数组(demo为int,string同理)

package xx
import (
   "database/sql/driver"
   "encoding/json"
)

type IntArray []int

// 入库。实现 driver.Valuer 接口,Value 返回 json value
func (j IntArray) Value() (driver.Value, error) {
   if len(j) == 0 {
   	return "", nil
   }

   bytes, err := json.Marshal(j)
   if err != nil {
   	return "", nil
   }

   return string(bytes), nil
}

// 出库。实现 sql.Scanner 接口,Scan 将 value 扫描至 Jsonb
func (j *IntArray) Scan(value interface{}) error {
   bytes, ok := value.([]byte)
   if !ok || len(bytes) == 0 {
   	return nil
   }

   result := IntArray{}
   err := json.Unmarshal(bytes, &result)
   *j = IntArray(result)
   return err
}



二、Json

有个需求。根据类型字段typecontent存储不同的结构体。 拿出来的时候对外暴露不同的结构体对象。隐藏content
我一开始的做法是把content声明为string, 然后拿出来的时候解析到不同的结构体。 倒也没啥毛病。但是总觉得别扭,要先转为[]byte再判断解析。

package xx
import (
	"database/sql/driver"
	"encoding/json"
)

type Json []byte

// 入库,自动调用
func (j Json) Value() (driver.Value, error) {
	if len(j) <= 4 {
		return "", nil
	}
	return string(j), nil
}

// 出库,自动调用
func (j *Json) Scan(value interface{}) error {
	bytes, _ := value.([]byte)
	if len(bytes) > 4 {
		*j = Json(bytes)
	}
	return nil
}

// 解析到,手动调用
func (j Json) ParseAs(to interface{}) (err error) {
	if len(j) > 0 {
		err = json.Unmarshal([]byte(j), to)
		if err != nil {
			log.Println("ERROR JSON 解析错误", err)
		}
	}
	return
}

三、布尔

布尔适用于数据库用tinyint存储两种状态。 我们默认1为true,0为false

type Boolean bool

func (b Boolean) Value() (driver.Value, error) {
	var v int64
	if b {
		v = 1
	}
	return v, nil
}

func (b *Boolean) Scan(value interface{}) (err error) {
	*b = (value.(int64) != 0)
	return
}

标签:return,nil,err,数据库,bytes,Value,json,error,Go
来源: https://blog.csdn.net/z772532526/article/details/121933822

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有