package main
import (
"database/sql/driver"
"encoding/json"
"errors"
"fmt"
"gorm.io/driver/mysql"
"gorm.io/gorm"
)
type JSON json.RawMessage
// 实现 sql.Scanner 接口,Scan 将 value 扫描至 Jsonb
func (j *JSON) Scan(value interface{}) error {
bytes, ok := value.([]byte)
if !ok {
return errors.New(fmt.Sprint("Failed to unmarshal JSONB value:", value))
}
result := json.RawMessage{}
err := json.Unmarshal(bytes, &result)
*j = JSON(result)
return err
}
// 实现 driver.Valuer 接口,Value 返回 json value
func (j JSON) Value() (driver.Value, error) {
if len(j) == 0 {
return nil, nil
}
return json.RawMessage(j).MarshalJSON()
}
type Product struct {
gorm.Model
A JSON `gorm:"type:json"`
}
func (Product) TableName() string {
return "student_Product"
}
func test_orm() {
dsn := "root:Admin123@tcp(127.0.0.1:3390)/abc?charset=utf8mb4&parseTime=True&loc=Local"
db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})
if err != nil {
panic(err)
}
db.AutoMigrate(&Product{})
}
func main() {
test_orm()
}
golang_gorm_设置mysql为json字段类型2023-04-11
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
推荐阅读更多精彩内容
- 在遗留的系统,可以存在这样的场景:非json类型字段,存储着json串。我们在select的时候,期望获取该字段中...
- MySQL5.7更新json类型字段中的某个key的值 函数json_replace() 转自https://ww...
- 在网站重构中,通常会进行数据结构的修改,所以添加,删除,增加mysql表的字段是难免的,有时为了方便,还会增加修改...
- 背景: 1、mysql5.7开始支持json类型字段;2、mybatis暂不支持json类型字段的处理,需要自己做...
- 最近在项目中有遇到过一个问题就是golang 在读取mysql 数据库时有个时间字段读出来的是0001-00-00...