Go语言实战案例-创建模型并自动迁移

在现代 Web 开发中,数据库操作是核心环节之一。传统方式下我们需要手动创建表结构,但这不仅繁琐,还容易出错。Go 语言常用的 ORM 框架 GORM 提供了自动迁移功能,可以根据定义的模型结构自动创建或更新数据库表,大大提升开发效率。

本文将带你一步步实现 在 Go 中定义模型并使用 GORM 自动迁移数据库表


一、环境准备

在开始之前,请确保你已经准备好以下环境:

  • Go 1.18+
  • MySQL 或 SQLite(演示中使用 MySQL)
  • GORM v2

安装 GORM 及 MySQL 驱动:

bash 复制代码
go get -u gorm.io/gorm
go get -u gorm.io/driver/mysql

二、定义数据库模型

在 GORM 中,模型(Model)就是一个 Go 结构体,它会与数据库中的表一一对应。

比如我们定义一个 User 模型:

go 复制代码
package main

import (
	"gorm.io/driver/mysql"
	"gorm.io/gorm"
	"log"
)

// User 用户模型
type User struct {
	ID       uint   `gorm:"primaryKey"` // 主键
	Name     string `gorm:"size:100"`   // 用户名,最大长度100
	Email    string `gorm:"unique"`     // 邮箱,唯一
	Age      int    // 年龄
	Password string `gorm:"size:255"`   // 密码
}

func main() {
	// 数据库连接字符串
	dsn := "root:123456@tcp(127.0.0.1:3306)/testdb?charset=utf8mb4&parseTime=True&loc=Local"

	// 连接数据库
	db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})
	if err != nil {
		log.Fatal("数据库连接失败: ", err)
	}

	// 自动迁移
	err = db.AutoMigrate(&User{})
	if err != nil {
		log.Fatal("自动迁移失败: ", err)
	}

	log.Println("数据库迁移成功!")
}

三、运行效果

  1. 运行 go run main.go
  2. 如果数据库 testdb 为空,程序会自动创建 users 表:
sql 复制代码
CREATE TABLE `users` (
  `id` bigint unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(100),
  `email` varchar(191) UNIQUE,
  `age` int,
  `password` varchar(255),
  PRIMARY KEY (`id`)
);
  1. 下次运行程序时,如果模型发生了变化,GORM 会自动更新表结构。

四、自动迁移的注意事项

  • 只会新增字段/索引:不会删除已有字段,避免误删数据。
  • 适合开发阶段使用 :生产环境建议使用数据库迁移工具(如 golang-migrate)进行严格版本管理。
  • 标签控制表结构 :通过结构体标签(gorm:"...")可以精确控制字段属性,例如大小、唯一约束、外键等。

五、总结

通过本案例,我们学习了如何在 Go 中使用 GORM:

  1. 定义模型(结构体 → 数据表)
  2. 使用 AutoMigrate 自动生成数据库表
  3. 灵活利用标签控制字段约束

这大大减少了手动维护 SQL 的工作量,让开发者更专注于业务逻辑。

相关推荐
Victor35618 分钟前
Redis(8)如何安装Redis?
后端
Victor35623 分钟前
Redis(9)如何启动和停止Redis服务?
后端
javachen__2 小时前
SpringBoot整合P6Spy实现全链路SQL监控
spring boot·后端·sql
uzong8 小时前
技术故障复盘模版
后端
GetcharZp8 小时前
基于 Dify + 通义千问的多模态大模型 搭建发票识别 Agent
后端·llm·agent
桦说编程9 小时前
Java 中如何创建不可变类型
java·后端·函数式编程
IT毕设实战小研9 小时前
基于Spring Boot 4s店车辆管理系统 租车管理系统 停车位管理系统 智慧车辆管理系统
java·开发语言·spring boot·后端·spring·毕业设计·课程设计
wyiyiyi9 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask