去构建错误"db.GetUsers undefined (type *gorm.DB has no field or method GetUsers)"



我是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.GetUsersdb属于未定义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)

最新更新