我是golang的新手,并尝试使用gin + gorm制作API服务器。
我试图构建下面的代码,但type *gorm.DB has no field or method GetUsers
错误。
这是一个非常简单的 API 服务器,只有我想做的是从表中获取所有用户users
。
package models
import (
"github.com/jinzhu/gorm"
_ "github.com/jinzhu/gorm/dialects/postgres"
)
var db *gorm.DB
func init() {
var err error
db, err = gorm.Open("postgres", "host=localhost dbname=test user=postgres password=test sslmode=disable")
if err != nil {
return err
}
}
type User struct {
ID int `json:"id"`
Username string `json:"name"`
}
func NewUser(id int, name string) User {
return User{
ID: id,
Username: name,
}
}
// UserRepository
type UserRepository struct {
}
func NewUserRepository() UserRepository {
return UserRepository{}
}
func (m UserRepository) GetUsers() []*User {
var users []*User
has, _ := db.GetUsers(&users)
if has {
return users
}
return nil
}
我在controllers/user.go
中实现了GetUsers()
,还创建了users
表。
我不知道为什么它说no field or method GetUsers
.有人给了我解决这个问题的建议。
package controllers
import (
"api-server/models"
)
type User struct {
}
func NewUser() User {
return User{}
}
func (c User) GetUsers() interface{} {
repo := models.NewUserRepository()
user := repo.GetUsers()
return user
}
试图在谢尔盖上面的回答下评论你的问题,但我没有特权,因为我是新来的。
正如谢尔盖所说,我看不到 GetUsers 在结构gorm.DB
功能。如果你db.Raw("select * from users").Scan(&users)
,你不能(也不需要(为语句分配两个变量。相反,只是:
db.Raw("select * from users").Scan(&users)
这是因为数据库。Scan(( 在数据库实现中只返回一个结果变量:
// Scan scan value to a struct
func (s *DB) Scan(dest interface{}) *DB {
return s.clone().NewScope(s.Value).Set("gorm:query_destination",dest).callCallbacks(s.parent.callbacks.queries).db
}
在问题中添加更多上下文后,更新了答案:
那是因为您实际上没有为gorm.DB
实现GetUsers
。你所做的是 - 在controllers
包中定义一个名为 User
的结构,并将一个GetUsers
方法附加到该结构。在controllers/User.GetUsers
里面,你调用了repo.GetUsers
,它在内部试图调用db.GetUsers
。 db
属于未定义GetUsers
方法的 *gorm.DB
类型。
一种解决方法是按照谢尔盖的建议,只需db.Raw(...).Scan(...)
.
如果你真的想封装戈尔姆。数据库,使GetUsers
从数据库连接看起来更原生,您可以尝试的一件事是:
type MyDB struct {
gorm.DB
}
func (m *MyDB) GetUsers() []*Users {
// do things like m.Raw(...).Scan(...)
}
在您的模型中,您将db
声明为类型 *MyDB
而不是 *gorm.DB
。
有关此嵌入技术的更多官方文档,请查看 https://golang.org/doc/effective_go.html#embedding
如果我在你的代码中看到我没有看到 GetUsers 函数数据库这个*戈姆。数据库但没有获取用户你需要这样
db..Raw("select * from users").Scan(&users)