go gorm gen 根据model,生成数据库表和查询

下载
go get gorm.io/gen

需要自己定义model

type UserDetail struct {
    ID         int64     `gorm:"column:id;type:bigint;primaryKey;autoIncrement:true" json:"id"`
    UserName   string    `gorm:"column:user_name;type:varchar(255);not null" json:"user_name"`
    NickName   string    `gorm:"column:nick_name;type:varchar(255);not null" json:"nick_name"`
    CreateTime time.Time `gorm:"column:create_time;type:datetime;not null;default:CURRENT_TIMESTAMP" json:"create_time"`
    UpdateTime time.Time `gorm:"column:update_time;type:datetime;not null;default:CURRENT_TIMESTAMP" json:"update_time"`
}

// TableName 表名
func (*UserDetail) TableName() string {
    return "tb_user"
}

定义查询


type UserMethod interface {
    // FindByUserName where("user_name=@userName")
    FindByUserName(userName string) (gen.T, error)

    // GetById where("id=@id")
    GetById(id int32) (gen.T, error)
}

main

func main() {
    db := manager.NewMySQL()
    //字段类型的修改需要单独处理,先删除然后再加上
    //db.Migrator().DropColumn(&UserDetail{}, "user_name")
    //db.Migrator().AddColumn(&model.UserDetail{}, "user_name")
    err := db.AutoMigrate(&model.UserDetail{}) // 自动同步数据库表

    if err != nil {
        fmt.Println(err)
        return
    }

    g := gen.NewGenerator(gen.Config{
        OutPath: "./dal/query",
        Mode:    gen.WithDefaultQuery | gen.WithQueryInterface,
    })

    g.UseDB(db)
    g.ApplyInterface(func(method method.UserMethod) {}, model.UserDetail{})
    g.Execute()

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值