关于GIN框架中初始化项目gorm表未生成介绍

大家都知道,gin框架中数据表的生成是通过AutoMigrate。

gorm 使用结构体标识 table ,即一个 struct 对应数据库里的一个 table 。

type BaseModel struct {
    ID        uint      `gorm:"primary_key" json:"id"`
    CreatedAt JsonTime  `json:"created_at"`
    UpdatedAt JsonTime  `json:"updated_at"`
    DeletedAt gorm.DeletedAt `sql:"index" json:"-"`
}

type User struct {
    BaseModel
    Username string `json:"username"`
    Password string `json:"password"`
    Avatar string `json:"avatar"`
    Age *int
}

err = db.AutoMigrate(&models.User{})
    if err != nil {
        log.Fatal(err)
    }

但是在特殊情况下,即使调用了AutoMigrate,也不会生成数据表。

err := *gorm.DB.AutoMigrate(&BaseModel{})
	if err != nil {
		return
	}

这个问题可能是项目启动顺序的问题


func init() {
	// 初始化项目配置
	setting.Setup()
	// 加载日志模块
	logging.Setup()
	// 加载数据库
	dao.Setup()
	// 加载路由
	router.Setup()
}

func main() {
	// 模型绑定
	err := *gorm.DB.AutoMigrate(&BaseModel{})
	if err != nil {
		return
	}
}

如上述代码,没有看到Run命令,是因为run命令被封装到了加载路由内,导致在init函数内项目就已经初始化完成,之后的main函数中AutoMigrate命令,未被加载。以至于表生成失败!

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一段基于gingorm的web项目的代码示例: ```go package main import ( "github.com/gin-gonic/gin" "gorm.io/driver/mysql" "gorm.io/gorm" ) type User struct { ID uint `gorm:"primaryKey"` Name string `gorm:"not null"` Age int `gorm:"not null"` } func main() { dsn := "user:password@tcp(127.0.0.1:3306)/db_name?charset=utf8mb4&parseTime=True&loc=Local" db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{}) if err != nil { panic("failed to connect database") } // Auto Migrate db.AutoMigrate(&User{}) r := gin.Default() // Get all users r.GET("/users", func(c *gin.Context) { var users []User db.Find(&users) c.JSON(200, users) }) // Create a user r.POST("/users", func(c *gin.Context) { var user User if err := c.ShouldBindJSON(&user); err != nil { c.JSON(400, gin.H{"error": err.Error()}) return } db.Create(&user) c.JSON(200, user) }) // Get a user by ID r.GET("/users/:id", func(c *gin.Context) { var user User if err := db.First(&user, c.Param("id")).Error; err != nil { c.JSON(404, gin.H{"error": "User not found"}) return } c.JSON(200, user) }) // Update a user by ID r.PUT("/users/:id", func(c *gin.Context) { var user User if err := db.First(&user, c.Param("id")).Error; err != nil { c.JSON(404, gin.H{"error": "User not found"}) return } if err := c.ShouldBindJSON(&user); err != nil { c.JSON(400, gin.H{"error": err.Error()}) return } db.Save(&user) c.JSON(200, user) }) // Delete a user by ID r.DELETE("/users/:id", func(c *gin.Context) { var user User if err := db.First(&user, c.Param("id")).Error; err != nil { c.JSON(404, gin.H{"error": "User not found"}) return } db.Delete(&user) c.JSON(200, gin.H{"message": "User deleted"}) }) r.Run(":8080") } ``` 这段代码实现了一个简单的用户管理系统,可以通过HTTP接口进行用户的增删改查操作。其使用了gin作为HTTP框架gorm作为ORM框架,MySQL作为数据库。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值