Back to Gin Vue Admin

Model 示例

aiDoc/examples/backend/model-example.md

2.9.21.2 KB
Original Source

Model 示例

这个文件负责什么

Model 负责定义数据库实体与持久化字段,是 Service 和数据库交互的基础。

什么时候应该这样写

  • 新增一张业务表
  • 为现有表补字段
  • 需要定义 GORM 结构与关联关系

推荐写法示例

go
package system

import "github.com/flipped-aurora/gin-vue-admin/server/global"

type Order struct {
	global.GVA_MODEL
	Name     string `json:"name" gorm:"comment:订单名称"`
	Status   int    `json:"status" gorm:"default:1;comment:订单状态"`
	Remark   string `json:"remark" gorm:"comment:备注"`
	CreatorID uint  `json:"creatorId" gorm:"comment:创建人ID"`
}

为什么这样写

  • 继承 global.GVA_MODEL,保持主键和时间字段风格一致
  • json 标签用于接口输出
  • gorm 标签用于约束字段类型、默认值和注释
  • 字段命名尽量清晰、稳定,便于前后端保持一致

常见错误

  • 缺少 jsongorm 标签
  • 把仅用于请求或展示的字段直接写入数据库 model
  • 同一个字段在前后端使用不同类型
  • 忽略 StatusID、时间字段这类高风险类型一致性问题

真实参考文件

  • server/model/system/sys_api_token.go
  • server/model/system/sys_user.go