Gorm AutoMigrate() 和 CreateTable() 不起作用

Nla*_*ALD 5 schema migrate go go-gorm

我已经在这里和谷歌上浏览过相关问题。

我正在使用 Gorm 和 SQLite3。

每当我尝试在结构上运行任一函数时,都会收到错误。当我调试并单步执行时,我看到表名称是“”。Gorm 没有获取我的结构名称,即 models.UserAuth。如果我调用 DropTable(models.UserAuth{}) 显示没有名为 user_auth 的表(但至少它找出了表名称)。当我浏览数据库时,当然没有表。

我的结构是

type UserAuth struct {
    gorm.Model
    ProfileID int      `gorm:"not null" json:"profile_id"`
    Username  string   `gorm:"size:20;unique_index" json:"username"`
    Email     string   `gorm:"type:varchar(100);unique_index" json:"email"`
    Password  string   `gorm:"not null" json:"password"`
    Remember  bool     `gorm:"not null" json:"remeber"`
    TwoFA     bool     `gorm:"not null" json:"twofa"`
    Access    int      `gorm:"not null" json:"access"`
    State     int      `gorm:"not null" json:"state"`
    LastSeen  string   `gorm:"not null" json:"lastseen"``
}
Run Code Online (Sandbox Code Playgroud)

我的常见迁移功能是:

func (d *Database) Migrate(m interface{}) {
    logEntry := fmt.Sprintf("Auto Migrating %s...", reflect.TypeOf(m))

    //d.db.DropTable(&models.UserAuth{})
    //d.db.CreateTable(&models.UserAuth{})

    // Do it the hard way
    //if d.db.HasTable(&m) == false {
    // Create table for model `User`
    //  d.db.CreateTable(&m)
    //  d.logThis.Info(fmt.Sprintf("%s %s with error %s", logEntry, "Failed", d.db.Error))
    //}

    // Migrate the schema
    db := d.db.AutoMigrate(&m) //<--- Line 84
    if db != nil && db.Error != nil {
        //We have an error
        d.logThis.Fatal(fmt.Sprintf("%s %s with error %s", logEntry, "Failed", db.Error))
    }
    d.logThis.Info(fmt.Sprintf("%s %s", logEntry, "Success"))
}
Run Code Online (Sandbox Code Playgroud)

最后,它是如何被调用的:

app.Db.Migrate(models.UserAuth{})
Run Code Online (Sandbox Code Playgroud)

调试时的实际输出:

({PathToProject}/database/database.go:84) 
[2018-07-23 06:12:24]  near ")": syntax error 

({PathToProject}/database/database.go:84) 
[2018-07-23 06:12:24]  [0.99ms]  CREATE TABLE "" ( )  
[0 rows affected or returned ] 
Run Code Online (Sandbox Code Playgroud)

仅供参考,否决票是没有必要的 - 这是一个合法的问题,因为我在文档摘要页面上采用了 gorm 示例,并且基本上只是更改了结构。并且该结构使用了正确的基本类型(除了返回到原始帖子的代码中的切片之外)并且该错误不是很有帮助。我看到空白表名错误之前有一个语法错误 - 但为什么呢?我给了 GORM 一个有效的结构吗?

chr*_*ris 4

我很确定 sqlite 没有您的 AuthIP 类型([]string)。我不确定 GORM 是否允许您编写自定义 Valuer 和 Scanner 接口方法,以允许您将字符串转换为数组并再次转换回来,但您可能想检查一下。

更新:更改db := d.db.AutoMigrate(&m)db := d.db.AutoMigrate(m)允许反射获取类型名称。

如果您实现该tabler接口,您还可以更好地控制表的名称。

https://github.com/jinzhu/gorm/blob/master/scope.go#L305

type tabler interface {
    TableName() string
}
Run Code Online (Sandbox Code Playgroud)