MySQL JSON_SET() 函数

1. 用到的关键技术

  1. MySQL JSON_SET() 函数 这是 MySQL 5.7+ 提供的原生 JSON 操作函数,专门用于修改 JSON 字段中的指定路径值,语法:

    sql

    复制代码
    JSON_SET(json字段, '$.路径.子字段', 新值)
    • $:代表 JSON 根节点
    • $.crypto.issuance_volume:定位到 options 字段下 crypto 对象里的 issuance_volume
    • 功能:存在该键则覆盖更新 ,不存在则新增键值对,不会破坏 JSON 字段里的其他数据
  2. GORM Expr() 表达式 GORM 的 gorm.Expr() 用于直接写入原生 SQL 片段,绕过 ORM 的字段映射,实现数据库原生函数调用,这是操作 JSON 字段的常用方案。

  3. 查询条件设计

    go运行

    复制代码
    "symbol":       data.Symbol,        // 币种编码(字符串)
    "symbol_crc32": php2go.Crc32(data.Symbol) // 币种编码的CRC32哈希值

    字符串 + 哈希值复合条件查询,配合数据库索引可以大幅提升查询效率,避免全表扫描。

2. 两段代码的执行效果

假设原 options 字段的 JSON 结构为:

json

复制代码
{
  "crypto": {
    "price": 50000,
    "issuance_volume": 0,
    "market_cap": 0
  },
  "other_info": "test"
}

执行代码后:

  • 第一段:更新 $.crypto.issuance_volume 为计算出的流通量
  • 第二段:更新 $.crypto.market_cap 为接口返回的市值
  • 最终 JSON 中仅这两个字段被修改,priceother_info 等数据完全保留

3.补充关键注意事项

  1. 字段类型要求 数据库中 options 字段必须是 JSON/JSONB 类型,普通字符串类型无法使用 JSON_SET 函数。

  2. 空值兼容 如果 issuanceVolumemarket_capnil/0JSON_SET 会正常写入,不会报错。

  3. 执行结果校验原代码没有判断更新是否成功,生产环境建议添加错误检查:

    go

    运行

    复制代码
    result := tx.Where(...).Updates(...)
    if result.Error != nil {
        // 处理更新失败逻辑,如日志记录、告警
        log.Errorf("更新币种%s数据失败:%v", data.Symbol, result.Error)
    }
  4. 事务建议批量更新币种数据时,建议开启数据库事务,保证批量操作的原子性(要么全部成功,要么全部回滚)。


总结

  1. 代码核心是通过 MySQL JSON_SET() + GORM 原生表达式 ,精准修改 options JSON 字段的嵌套值,不影响其他字段;
  2. 原代码分两次更新同一条数据存在冗余,合并为一次更新是最优优化方案;
  3. 该方案是 Go + GORM 操作 MySQL JSON 字段的标准实践,兼顾了灵活性和性能
相关推荐
海市公约15 分钟前
MySQL更新语句执行全流程:从Buffer Pool修改到二阶段提交
数据库·mysql·binlog·innodb·undo log·二阶段提交·update执行原理
颂love35 分钟前
MySQL的执行流程
android·数据库·mysql
海市公约1 小时前
一条SQL查询的完整旅程:MySQL执行流程深度解析
sql·mysql·数据库优化·执行计划·连接器·查询缓存·sql执行原理
程序leo源1 小时前
Qt窗口详解
开发语言·数据库·c++·qt·青少年编程·c#
这个DBA有点耶1 小时前
COUNT进阶:超大表的近似计数与HyperLogLog
数据库·sql·程序人生·学习方法·dba·改行学it
武子康1 小时前
调查研究-138 全球机器人产业深度调研报告【01 篇】:市场规模、竞争格局与商业化成熟 2026
服务器·数据库·ai·chatgpt·机器人·具身智能
zhojiew2 小时前
在本地PostgreSQL使用pgvector构建生成式 AI 应用的实践
数据库·人工智能·postgresql
Yushan Bai2 小时前
EXADATA X5数据库一体机节点login: failure forking: Cannot allocate memory问题处理
数据库·oracle·vr
KaMeidebaby2 小时前
卡梅德生物技术快报|噬菌体肽库展示技术构建 Mhp168‑Hsp70 定向随机肽库:流程、质控与数据结果
前端·数据库·其他·百度·新浪微博
沪漂阿龙2 小时前
MySQL 面试题爆款详解:InnoDB 页机制、B+树索引、Buffer Pool、Redo Log、页分裂与性能优化一次讲透
b树·mysql·性能优化