尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

Gorm自定义数据类型

Gorm自定义数据类型
📅 发布时间:2026/6/19 12:09:31

参考官网 https://gorm.io/zh_CN/docs/data_types.html

现在有个需求是,数据库存了用户解锁的头像数组,每次都要json序列化和反序列化.之前是给Avatar结构体写了两个方法,发现太麻烦了

Scan和Value分别对应读取和存储。同理,可以扩展其他类型,比如时间

package domainimport ("database/sql/driver""encoding/json""errors"
)// AvatarListJSON 自定义int切片类型,用于数据库JSON字段的自动序列化和反序列化
type AvatarListJSON []int// Scan 实现sql.Scanner接口,从数据库读取JSON数据并转换为AvatarListJSON
func (al *AvatarListJSON) Scan(value interface{}) error {bytes, ok := value.([]byte)if !ok {return errors.New("invalid type for AvatarListJSON")}if len(bytes) == 0 {*al = []int{}return nil}var temp []intif err := json.Unmarshal(bytes, &temp); err != nil {return err}*al = AvatarListJSON(temp)return nil
}// Value 实现driver.Valuer接口,将AvatarListJSON转换为JSON字符串存储到数据库
func (al AvatarListJSON) Value() (driver.Value, error) {if len(al) == 0 {return "[]", nil}bytes, err := json.Marshal(al)if err != nil {return nil, err}return string(bytes), nil
}// Avatar 头像结构体
type Avatar struct {ID     int64          `gorm:"primaryKey" json:"id"`UID    int            `gorm:"index" json:"uid"`              // 所属用户Avatar AvatarListJSON `gorm:"column:avatar" json:"avatar"`  // 头像id列表,JSON格式存储
}func (*Avatar) TableName() string {return "avatar"
}

相关新闻

  • PHP流量控制令牌桶算法
  • 顽固文件夹无法删除?
  • c++ std::map

最新新闻

  • 有据可查!南宁黄金回收公信力榜单出炉,变现直接对照选店 - 沉迷学习28
  • 离婚财产分割律所:5家精通复杂资产分割的团队评测 - 品牌2026
  • 如何用OandBackup打造你的安卓数据安全堡垒?终极备份解决方案深度解析
  • 同样一款香奈儿,武汉回收店差价巨大?揭秘行业压价底层套路 - 奢侈品交易观察员
  • 如何在React中快速实现复制到剪贴板功能:终极react-copy-to-clipboard完整指南
  • 长沙手表回收高价变现技巧2026:5个核心方法+靠谱机构推荐 - 逸程

日新闻

  • 5分钟掌握Python进化算法:Geatpy高性能优化工具完全指南
  • Microchip 24AA044 EEPROM选型与应用全指南:从参数解析到实战编程
  • 华为的鸿蒙到底有多牛?为什么称作遥遥领先?

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号