我需要查询数据库的功能。
我使用github.com/gocraft/dbr,所以我创建了辅助函数:
//SelectData - selects data from database
func SelectData(table, fields, where string, data interface{}) interface{} {
var ptr reflect.Value
ptr = reflect.New(reflect.TypeOf(data)) // create new pointer
obj := ptr.Interface()
sess := Session
query := sess.Select(fields).
From(table)
if len(where) > 0 {
query.Where(where)
}
_, err := query.Load(obj)
if err != nil {
panic(err)
}
return obj
}
然后我尝试使用它:
//CheckUser - checks is user registered in db
func CheckUser(userid string) User {
var user User
var i interface{}
i = db.SelectData("users", "*", "", user)
fmt.Printf("=%#v \n", i)
user = i.(User)
return user
}
但是我遇到运行时错误:
interface conversion: interface {} is *models.User, not models.User
D:/Go/src/runtime/panic.go:513 (0x42ccb6)
gopanic: reflectcall(nil, unsafe.Pointer(d.fn), deferArgs(d), uint32(d.siz), uint32(d.siz))
D:/Go/src/runtime/iface.go:248 (0x4091ac)
panicdottypeE: panic(&TypeAssertionError{iface, have, want, ""})
C:/Users/vasalt/go/src/wcenter/models/model_user.go:29 (0x9dda3a)
CheckUser: user = i.(User)
C:/Users/vasalt/go/src/wcenter/controllers/ctrl_main.go:59 (0x9e03b6)
SetPageData: fmt.Printf("=result = %#v\n", models.CheckUser("1234"))
并调试输出:
=&models.User{UID:sql.NullString{String:"1", Valid:true}, UserID:sql.NullString{String:"1234", Valid:true}, UserGroup:sql.NullString{String:"1", Valid:true}}
因此它成功地从datbase检索了数据,但它不仅返回了&models.User
,而且还返回了models.User
,我不知道如何将interface{}
的{{1}}转换为*models.User
答案 0 :(得分:3)
我认为这应该有效。您可以将其强制转换为* User并返回User值或* User,具体取决于您的用例。
user = i.(*User)
return *user
答案 1 :(得分:1)
ptr = reflect.New(reflect.TypeOf(data)) // create new pointer obj := ptr.Interface()
reflect.New
返回代表一个指向新数据类型实体的指针的反射值。ptr.Interface()
返回类型为* data的ptr
的实际值。
因此,当您调用i = db.SelectData("users", "*", "", user)
时,它将返回* User。除i.(User)
之外,不能使用类型断言i.(*User)
。