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...