gorm存储json

在一些存储配置文件的场景下,我们需要在mysql中存储json。最直接的方法是在存储时通过json.Marshall()序列化方法将需要存储的对象转化为json字符串,然后再存入mysql中。需要使用时,从mysql中取出,再进行json.Unmarshall()。具体操作如下:

go 复制代码
type Record struct {
	Config string `json:"config" gorm:"column:config"` //
}

func main() {
	// 存储示例
	config1 := map[string]any{
		"配置项1": 1,
		"配置项2": "二",
		"配置项3": true,
	}
	tmp, _ := json.Marshal(config1)
	record1 := Record{
		Config: string(tmp),
	}
	db.Save(record1)

	// 使用示例
	record2 := Record{}
	db.Find(record2)
	config2 := map[string]any{}
	json.Unmarshal([]byte(record2.Config),config2)
}

每次进行类似的操作都需要进行转换,十分的繁琐。有没有一种办法能让存储和取出的过程中自动完成对象和json字符串之间的互换呢?

gorm提供了钩子函数,可以很好的解决这个问题。

Hook 是在创建、查询、更新、删除等操作之前、之后调用的函数。

如果您已经为模型定义了指定的方法,它会在创建、更新、查询、删除时自动被调用。如果任何回调返回错误,GORM 将停止后续的操作并回滚事务。

钩子方法的函数签名应该是 func(*gorm.DB) error

以上面的操作为例,我们可以为其添加钩子函数,并修改结构体

go 复制代码
type Record struct {
	Config    map[string]any `json:"config" gorm:"-"`
	RawConfig string         `json:"-" gorm:"column:config"`
}

func (r *Record) BeforeSave(tx *gorm.DB) error {
	if r.Config != nil {
		tmp, err := json.Marshal(r.Config)
		if err != nil {
			return err
		}
		r.RawConfig = string(tmp)
	}
	return nil
}

func (r *Record) AfterFind(tx *gorm.DB) error {
	if r.RawConfig != "" {
		err := json.Unmarshal([]byte(r.RawConfig), &r.Config)
		return err
	}
	return nil
}

这是我们在使用时直接操控Config即可完成操作,不需要再将数据进行转换

相关推荐
武子康2 小时前
Java-144 深入浅出 MongoDB BSON详解:MongoDB核心存储格式与JSON的区别与应用场景
java·开发语言·数据库·mongodb·性能优化·json·bjson
她说彩礼65万7 小时前
Asp.net core appsettings.json` 和 `appsettings.Development.json`文件区别
后端·json·asp.net
技术钱1 天前
vue3 两份json数据对比不同的页面给于颜色标识
前端·vue.js·json
你们瞎搞1 天前
arcgis矢量数据转为标准geojson格式
python·arcgis·json·地理空间数据
青草地溪水旁3 天前
Visual Studio Code中launch.json深度解析:C++调试的艺术
c++·vscode·json
Zwb2997925 天前
Day 30 - 错误、异常与 JSON 数据 - Python学习笔记
笔记·python·学习·json
眠りたいです5 天前
基于脚手架微服务的视频点播系统-脚手架开发部分-jsoncpp,protobuf,Cpp-httplib与WebSocketpp中间件介绍与使用
c++·websocket·微服务·中间件·json·protobuf·cpp-httplib
我是大头鸟5 天前
XMLHttpRequest 发送json 格式的数据,servlet 接收
servlet·json·xmlhttprequest
程序新视界6 天前
一篇文章详解你不知道的MySQL JSON数据类型
数据库·mysql·json
数据知道6 天前
Go基础:json文件处理详解(标准库`encoding/json`)
开发语言·后端·golang·json·go语言