1 回答
TA贡献1806条经验 获得超8个赞
您省略的实际错误消息就在恐慌堆栈跟踪之前:
http: panic serving [::1]:53017: runtime error: invalid memory address or nil pointer dereference
这是一些指针尚未设置且等于 的提示nil。
当深入挖掘时,我发现当请求到达您的方法时,它repo.db没有设置( ) ,这就是它恐慌的原因。== nilGetBalancerepo.db.Where
您尝试在main.go文件中设置此字段,您还可以在其中加载数据库:
var db *gorm.DB
{
dbDriver := "sqlite3"
dbName := "demo.db"
db, err := gorm.Open(dbDriver, dbName)
if err != nil {
_ = level.Error(logger).Log("exit", err)
os.Exit(-1)
}
db.AutoMigrate(&Entity.UserEntity{})
}
这段代码包含一个微妙的错误,它与变量阴影有关。基本上,您db上面声明的变量与括号中声明的变量不同,{}括号中的变量是一个单独的数据库。您可以通过重命名或不再声明它来解决这个问题(使用:=):
var db *gorm.DB
{
dbDriver := "sqlite3"
dbName := "demo.db"
dbLoaded, err := gorm.Open(dbDriver, dbName) // Rename the variable
if err != nil {
_ = level.Error(logger).Log("exit", err)
os.Exit(-1)
}
dbLoaded.AutoMigrate(&Entity.UserEntity{})
db = dbLoaded // Set `db` of the outer scope to `dbLoaded` of this scope
} // dbLoaded is lost here, but it can be accessed using `db`
现在它正确加载了数据库(db不再是nil),并且您的其他模块中的访问现在也可以正常工作。
- 1 回答
- 0 关注
- 98 浏览
添加回答
举报