我将这个ORM库用于PostgreSQL:https://godoc.org/github.com/go-pg/pg#example-DB-Select,但遇到一个奇怪的问题,我不理解。
我正在尝试SELECT
表中的数据settings
,以便以后使用函数更新该值。
package settingsmodel
import (
. "database"
)
type Settings struct {
Id int64
SiteName string
}
func Set(newValue string) bool {
site := &Settings {
SiteName: "MySite",
}
err := Db.Select(&site)
if err != nil {
panic(err) // This is where it panics
}
site.SiteName = newValue
err = Db.Update(site)
if err != nil {
panic(err)
}
return true
}
我得到的错误是panic: pg: Model(unsupported *settingsmodel.Settings)
我有另一个函数(在同一文件中),可以获取站点名称,并且可以正常运行:
func Get() string {
var site Settings
err := Db.Model(&site).First()
if err != nil {
panic(err)
}
return site.SiteName
}
我真的不明白为什么它不起作用。有什么帮助吗?谢谢!
答案 0 :(得分:0)
在工作示例中,您正在传递一个指向设置的指针。在第一个(无效)示例中,您将指针传递给指针:
// &Settings - site is a pointer to a Settings struct
site := &Settings {
SiteName: "MySite",
}
// &site - pass a pointer to site, which is already a pointer
err := Db.Select(&site)
vs工作人员:
// site is a value, not a pointer
var site Settings
// Pass a pointer to the value
err := Db.Model(&site).First()