GORM 的 Migration API

GORM 的 Migration API(迁移接口) 是一套用于管理数据库结构变更的工具,主要用于在程序运行时自动或手动同步数据表结构,确保数据库 Schema 与代码中的模型保持一致。

核心功能:

  1. AutoMigrate(自动迁移)

    通过 db.AutoMigrate(&User{}) 可自动创建表、缺失的外键、约束、列和索引。它会根据结构体定义更新数据库结构,但不会删除未使用的列 ,以保护已有数据安全。

    示例:

    go 复制代码
    db.AutoMigrate(&User{}, &Product{})
  2. Migrator 接口

    GORM 提供统一的 Migrator 接口,用于执行更精细的数据库结构操作,如:

    • 创建/删除表
    • 添加/删除列
    • 添加/删除索引
    • 检查表或索引是否存在(如 HasTable, HasIndex
    • 重命名索引等
      这个接口为不同数据库(如 SQLite、MySQL、PostgreSQL)提供一致的操作方式,屏蔽底层 SQL 差异。
  3. 外键与约束支持

    在 AutoMigrate 或建表时,GORM 默认会自动创建外键约束,但可以通过配置关闭:

    go 复制代码
    db, err := gorm.Open(sqlite.Open("gorm.db"), &gorm.Config{
        DisableForeignKeyConstraintWhenMigrating: true,
    })

    同时支持使用 check 标签添加数据库检查约束。

  4. 数据库兼容性处理

    针对不支持某些 DDL 操作的数据库(如 SQLite 不支持 ALTER COLUMN),GORM 会智能地通过"新建表 → 复制数据 → 删除旧表 → 重命名新表"的方式完成结构变更。


✅ 总结:

GORM 的 Migration API 是一套强大且易用的数据库结构管理工具,包含 AutoMigrate 自动同步机制和 Migrator 手动控制接口,帮助开发者在不直接写 SQL 的前提下,安全高效地管理数据库变更。

相关推荐
GZ_TOGOGO1 小时前
Oracle数据库考试适合哪些人
数据库·oracle·数据库开发·ocp认证·2026年it学习
Gauss松鼠会1 小时前
【openGauss】学习 gsql 命令行的使用
数据库·sql·database·opengauss
晓13132 小时前
第二章:Redis常见命令与Java客户端
java·数据库·redis
·云扬·2 小时前
MySQL索引实战指南:添加场景、联合索引要点与失效场景解析
数据库·mysql
填满你的记忆2 小时前
【从零开始——Redis 进化日志|Day7】双写一致性难题:数据库与缓存如何不再“打架”?(附 Canal/读写锁实战)
java·数据库·redis·缓存·面试
小白考证进阶中2 小时前
MySQL OCP认证可以考中文?备考难度怎么样?
数据库·mysql·dba·数据库管理·开闭原则·数据库管理员·mysql认证
蒟蒻的贤2 小时前
操作系统复习
java·开发语言·数据库
Dontla2 小时前
打开网站时弹出Accept Cookies(接受Cookie)提示是什么意思?(数据保护法规,欧盟GDPR)
前端·数据库
赵八斤2 小时前
java 项目中配置多个数据源
java·开发语言·数据库
松涛和鸣3 小时前
59、 IMX6ULL按键驱动开发:轮询到中断的实现
linux·服务器·c语言·arm开发·数据库·驱动开发